NIFI-10303 route GetElasticsearch to failure if _id is blank after attribute evaluation

This closes #6573

Signed-off-by: Mike Thomsen <mthomsen@apache.org>
This commit is contained in:
Chris Sampson 2022-10-24 20:44:17 +01:00 committed by Mike Thomsen
parent db49a861b3
commit b6026f5709
2 changed files with 39 additions and 16 deletions

View File

@ -35,8 +35,10 @@ import org.apache.nifi.processor.AbstractProcessor;
import org.apache.nifi.processor.ProcessContext; import org.apache.nifi.processor.ProcessContext;
import org.apache.nifi.processor.ProcessSession; import org.apache.nifi.processor.ProcessSession;
import org.apache.nifi.processor.Relationship; import org.apache.nifi.processor.Relationship;
import org.apache.nifi.processor.exception.ProcessException;
import org.apache.nifi.processor.util.StandardValidators; import org.apache.nifi.processor.util.StandardValidators;
import org.apache.nifi.util.StopWatch; import org.apache.nifi.util.StopWatch;
import org.apache.nifi.util.StringUtils;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
@ -161,6 +163,10 @@ public class GetElasticsearch extends AbstractProcessor implements Elasticsearch
final String attributeName = context.getProperty(ATTRIBUTE_NAME).evaluateAttributeExpressions(input).getValue(); final String attributeName = context.getProperty(ATTRIBUTE_NAME).evaluateAttributeExpressions(input).getValue();
try { try {
if (StringUtils.isBlank(id)) {
throw new ProcessException(ID.getDisplayName() + " is blank (after evaluating attribute expressions), cannot GET document");
}
final StopWatch stopWatch = new StopWatch(true); final StopWatch stopWatch = new StopWatch(true);
final Map<String, Object> doc = clientService.get(index, type, id, getUrlQueryParameters(context, input)); final Map<String, Object> doc = clientService.get(index, type, id, getUrlQueryParameters(context, input));
@ -182,6 +188,19 @@ public class GetElasticsearch extends AbstractProcessor implements Elasticsearch
session.getProvenanceReporter().receive(documentFlowFile, clientService.getTransitUrl(index, type), stopWatch.getElapsed(TimeUnit.MILLISECONDS)); session.getProvenanceReporter().receive(documentFlowFile, clientService.getTransitUrl(index, type), stopWatch.getElapsed(TimeUnit.MILLISECONDS));
session.transfer(documentFlowFile, REL_DOC); session.transfer(documentFlowFile, REL_DOC);
} catch (final ElasticsearchException ese) { } catch (final ElasticsearchException ese) {
handleElasticsearchException(ese, input, session, index, type, id);
} catch (final Exception ex) {
getLogger().error("Could not fetch document.", ex);
if (input != null) {
input = session.putAttribute(input, "elasticsearch.get.error", ex.getMessage());
session.transfer(input, REL_FAILURE);
}
context.yield();
}
}
private void handleElasticsearchException(final ElasticsearchException ese, FlowFile input, final ProcessSession session,
final String index, final String type, final String id) {
if (ese.isNotFound()) { if (ese.isNotFound()) {
if (input != null) { if (input != null) {
session.transfer(input, REL_NOT_FOUND); session.transfer(input, REL_NOT_FOUND);
@ -198,13 +217,5 @@ public class GetElasticsearch extends AbstractProcessor implements Elasticsearch
session.transfer(input, ese.isElastic() ? REL_RETRY : REL_FAILURE); session.transfer(input, ese.isElastic() ? REL_RETRY : REL_FAILURE);
} }
} }
} catch (final Exception ex) {
getLogger().error("Could not fetch document.", ex);
if (input != null) {
input = session.putAttribute(input, "elasticsearch.get.error", ex.getMessage());
session.transfer(input, REL_FAILURE);
}
context.yield();
}
} }
} }

View File

@ -191,6 +191,18 @@ class GetElasticsearchTest {
@Test @Test
void testRequestParameters() { void testRequestParameters() {
final TestRunner runner = createRunner()
runner.setProperty(GetElasticsearch.ID, "\${noAttribute}")
runProcessor(runner)
testCounts(runner, 0, 1, 0, 0)
final FlowFile failed = runner.getFlowFilesForRelationship(GetElasticsearch.REL_FAILURE).get(0)
failed.assertAttributeEquals("elasticsearch.get.error", GetElasticsearch.ID.getDisplayName() + " is blank (after evaluating attribute expressions), cannot GET document")
reset(runner)
}
@Test
void testEmptyId() {
final TestRunner runner = createRunner() final TestRunner runner = createRunner()
runner.setProperty("refresh", "true") runner.setProperty("refresh", "true")
runner.setProperty("_source", '${source}') runner.setProperty("_source", '${source}')