From 6f3ca1c142fe7449b14a15f288a12fcb1354018f Mon Sep 17 00:00:00 2001 From: "opensearch-trigger-bot[bot]" <98922864+opensearch-trigger-bot[bot]@users.noreply.github.com> Date: Fri, 25 Oct 2024 14:11:56 -0700 Subject: [PATCH] FIX: missed exception in plugin error (#4945) (#5105) * FIX: missed exception in plugin error building Signed-off-by: George Chen (cherry picked from commit 13dccc447f1d01e033fce8d9dde55fd1059bedc9) Co-authored-by: Qi Chen --- .../parser/PipelineTransformer.java | 1 + .../dataprepper/TestDataProvider.java | 3 ++ .../parser/PipelineTransformerTests.java | 33 +++++++++++++++++-- .../connected_pipeline_incorrect_buffer.yml | 23 +++++++++++++ ...connected_pipeline_incorrect_processor.yml | 23 +++++++++++++ .../connected_pipeline_incorrect_sink.yml | 22 +++++++++++++ 6 files changed, 102 insertions(+), 3 deletions(-) create mode 100644 data-prepper-core/src/test/resources/connected_pipeline_incorrect_buffer.yml create mode 100644 data-prepper-core/src/test/resources/connected_pipeline_incorrect_processor.yml create mode 100644 data-prepper-core/src/test/resources/connected_pipeline_incorrect_sink.yml diff --git a/data-prepper-core/src/main/java/org/opensearch/dataprepper/parser/PipelineTransformer.java b/data-prepper-core/src/main/java/org/opensearch/dataprepper/parser/PipelineTransformer.java index c57c5eab61..98f0ae4942 100644 --- a/data-prepper-core/src/main/java/org/opensearch/dataprepper/parser/PipelineTransformer.java +++ b/data-prepper-core/src/main/java/org/opensearch/dataprepper/parser/PipelineTransformer.java @@ -149,6 +149,7 @@ private void buildPipelineFromConfiguration( .componentType(PipelineModel.BUFFER_PLUGIN_TYPE) .pipelineName(pipelineName) .pluginName(bufferPluginSetting.getName()) + .exception(e) .build(); pluginErrorCollector.collectPluginError(pluginError); } diff --git a/data-prepper-core/src/test/java/org/opensearch/dataprepper/TestDataProvider.java b/data-prepper-core/src/test/java/org/opensearch/dataprepper/TestDataProvider.java index aa72bbf207..2d86f62652 100644 --- a/data-prepper-core/src/test/java/org/opensearch/dataprepper/TestDataProvider.java +++ b/data-prepper-core/src/test/java/org/opensearch/dataprepper/TestDataProvider.java @@ -16,6 +16,9 @@ public class TestDataProvider { public static final String VALID_OFF_HEAP_FILE_WITH_ACKS = "src/test/resources/multiple_pipeline_valid_off_heap_buffer_with_acks.yml"; public static final String DISCONNECTED_VALID_OFF_HEAP_FILE_WITH_ACKS = "src/test/resources/multiple_disconnected_pipeline_valid_off_heap_buffer_with_acks.yml"; public static final String CONNECTED_PIPELINE_ROOT_SOURCE_INCORRECT = "src/test/resources/connected_pipeline_incorrect_root_source.yml"; + public static final String CONNECTED_PIPELINE_BUFFER_INCORRECT = "src/test/resources/connected_pipeline_incorrect_buffer.yml"; + public static final String CONNECTED_PIPELINE_PROCESSOR_INCORRECT = "src/test/resources/connected_pipeline_incorrect_processor.yml"; + public static final String CONNECTED_PIPELINE_SINK_INCORRECT = "src/test/resources/connected_pipeline_incorrect_sink.yml"; public static final String CONNECTED_PIPELINE_CHILD_PIPELINE_INCORRECT_DUE_TO_SINK = "src/test/resources/connected_pipeline_incorrect_child_pipeline_due_to_invalid_sink.yml"; public static final String CONNECTED_PIPELINE_CHILD_PIPELINE_INCORRECT_DUE_TO_PROCESSOR = "src/test/resources/connected_pipeline_incorrect_child_pipeline_due_to_invalid_processor.yml"; public static final String CYCLE_MULTIPLE_PIPELINE_CONFIG_FILE = "src/test/resources/cyclic_multiple_pipeline_configuration.yml"; diff --git a/data-prepper-core/src/test/java/org/opensearch/dataprepper/parser/PipelineTransformerTests.java b/data-prepper-core/src/test/java/org/opensearch/dataprepper/parser/PipelineTransformerTests.java index bcddc49b94..663dd8dd1e 100644 --- a/data-prepper-core/src/test/java/org/opensearch/dataprepper/parser/PipelineTransformerTests.java +++ b/data-prepper-core/src/test/java/org/opensearch/dataprepper/parser/PipelineTransformerTests.java @@ -207,18 +207,37 @@ void parseConfiguration_with_multiple_disconnected_valid_pipelines_creates_the_c assertThat(pipeline.getSource().areAcknowledgementsEnabled(),equalTo(false)); } - @Test - void parseConfiguration_with_invalid_root_pipeline_creates_empty_pipelinesMap() { + void parseConfiguration_with_invalid_root_source_pipeline_creates_empty_pipelinesMap() { final PipelineTransformer pipelineTransformer = createObjectUnderTest(TestDataProvider.CONNECTED_PIPELINE_ROOT_SOURCE_INCORRECT); final Map connectedPipelines = pipelineTransformer.transformConfiguration(); assertThat(connectedPipelines.size(), equalTo(0)); verify(dataPrepperConfiguration).getPipelineExtensions(); + assertThat(pluginErrorCollector.getPluginErrors().size(), equalTo(2)); + final PluginError sourcePluginError = pluginErrorCollector.getPluginErrors().get(0); + assertThat(sourcePluginError.getPipelineName(), equalTo("test-pipeline-1")); + assertThat(sourcePluginError.getPluginName(), equalTo("file")); + assertThat(sourcePluginError.getException(), notNullValue()); + // Buffer plugin gets error due to instantiated source is null + final PluginError bufferPluginError = pluginErrorCollector.getPluginErrors().get(1); + assertThat(bufferPluginError.getPipelineName(), equalTo("test-pipeline-1")); + assertThat(bufferPluginError.getPluginName(), equalTo("bounded_blocking")); + assertThat(bufferPluginError.getException(), notNullValue()); + } + + @ParameterizedTest + @MethodSource("provideInvalidPipelineResourceAndFailedPluginNameArgs") + void parseConfiguration_with_invalid_root_pipeline_creates_empty_pipelinesMap( + final String pipelineResourcePath, final String failedPluginName) { + final PipelineTransformer pipelineTransformer = createObjectUnderTest(pipelineResourcePath); + final Map connectedPipelines = pipelineTransformer.transformConfiguration(); + assertThat(connectedPipelines.size(), equalTo(0)); + verify(dataPrepperConfiguration).getPipelineExtensions(); assertThat(pluginErrorCollector.getPluginErrors().size(), equalTo(1)); final PluginError pluginError = pluginErrorCollector.getPluginErrors().get(0); assertThat(pluginError.getPipelineName(), equalTo("test-pipeline-1")); - assertThat(pluginError.getPluginName(), equalTo("file")); + assertThat(pluginError.getPluginName(), equalTo(failedPluginName)); assertThat(pluginError.getException(), notNullValue()); } @@ -525,6 +544,14 @@ private static Stream provideGetSecondaryBufferArgs() { ); } + private static Stream provideInvalidPipelineResourceAndFailedPluginNameArgs() { + return Stream.of( + Arguments.of(TestDataProvider.CONNECTED_PIPELINE_BUFFER_INCORRECT, "invalid_buffer"), + Arguments.of(TestDataProvider.CONNECTED_PIPELINE_PROCESSOR_INCORRECT, "invalid_processor"), + Arguments.of(TestDataProvider.CONNECTED_PIPELINE_SINK_INCORRECT, "invalid_sink") + ); + } + private Map>>> generateBufferMap(final int outerMapEntryCount, final int innerMapEntryCount) { final Map>>> bufferMap = new HashMap<>(); for (int i = 0; i < outerMapEntryCount; i++) { diff --git a/data-prepper-core/src/test/resources/connected_pipeline_incorrect_buffer.yml b/data-prepper-core/src/test/resources/connected_pipeline_incorrect_buffer.yml new file mode 100644 index 0000000000..54a8b5a7e2 --- /dev/null +++ b/data-prepper-core/src/test/resources/connected_pipeline_incorrect_buffer.yml @@ -0,0 +1,23 @@ +# this configuration file is solely for testing formatting +test-pipeline-1: + source: + stdin: + buffer: + invalid_buffer: #this plugin fails + sink: + - pipeline: + name: "test-pipeline-2" +test-pipeline-2: + source: + pipeline: + name: "test-pipeline-1" + sink: + - pipeline: + name: "test-pipeline-3" +test-pipeline-3: + source: + pipeline: + name: "test-pipeline-2" + sink: + - file: + path: "/tmp/todelete.txt" \ No newline at end of file diff --git a/data-prepper-core/src/test/resources/connected_pipeline_incorrect_processor.yml b/data-prepper-core/src/test/resources/connected_pipeline_incorrect_processor.yml new file mode 100644 index 0000000000..d2ffabb92b --- /dev/null +++ b/data-prepper-core/src/test/resources/connected_pipeline_incorrect_processor.yml @@ -0,0 +1,23 @@ +# this configuration file is solely for testing formatting +test-pipeline-1: + source: + stdin: + processor: + - invalid_processor: # this plugin should fail + sink: + - pipeline: + name: "test-pipeline-2" +test-pipeline-2: + source: + pipeline: + name: "test-pipeline-1" + sink: + - pipeline: + name: "test-pipeline-3" +test-pipeline-3: + source: + pipeline: + name: "test-pipeline-2" + sink: + - file: + path: "/tmp/todelete.txt" \ No newline at end of file diff --git a/data-prepper-core/src/test/resources/connected_pipeline_incorrect_sink.yml b/data-prepper-core/src/test/resources/connected_pipeline_incorrect_sink.yml new file mode 100644 index 0000000000..813edec81f --- /dev/null +++ b/data-prepper-core/src/test/resources/connected_pipeline_incorrect_sink.yml @@ -0,0 +1,22 @@ +# this configuration file is solely for testing formatting +test-pipeline-1: + source: + stdin: + sink: + - pipeline: + name: "test-pipeline-2" + - invalid_sink: # this plugin should fail +test-pipeline-2: + source: + pipeline: + name: "test-pipeline-1" + sink: + - pipeline: + name: "test-pipeline-3" +test-pipeline-3: + source: + pipeline: + name: "test-pipeline-2" + sink: + - file: + path: "/tmp/todelete.txt" \ No newline at end of file