mirror of https://github.com/apache/nifi.git
NIFI-10387: Fixed negative logic bug in scripted components (#6325)
This commit is contained in:
parent
90aa778a6c
commit
6f0ca87304
|
@ -241,9 +241,9 @@ public class BaseScriptedLookupService extends AbstractScriptedControllerService
|
||||||
public void setup() {
|
public void setup() {
|
||||||
if (scriptNeedsReload.get() || lookupService.get() == null) {
|
if (scriptNeedsReload.get() || lookupService.get() == null) {
|
||||||
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
||||||
scriptNeedsReload.set(reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
scriptNeedsReload.set(!reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
||||||
} else {
|
} else {
|
||||||
scriptNeedsReload.set(reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
scriptNeedsReload.set(!reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -225,9 +225,9 @@ public class InvokeScriptedProcessor extends AbstractSessionFactoryProcessor {
|
||||||
public void setup() {
|
public void setup() {
|
||||||
if (scriptNeedsReload.get() || processor.get() == null) {
|
if (scriptNeedsReload.get() || processor.get() == null) {
|
||||||
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
||||||
scriptNeedsReload.set(reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
scriptNeedsReload.set(!reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
||||||
} else {
|
} else {
|
||||||
scriptNeedsReload.set(reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
scriptNeedsReload.set(!reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,9 +107,9 @@ public class ScriptedRecordSink extends AbstractScriptedControllerService implem
|
||||||
public void setup() {
|
public void setup() {
|
||||||
if (scriptNeedsReload.get() || recordSink.get() == null) {
|
if (scriptNeedsReload.get() || recordSink.get() == null) {
|
||||||
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
||||||
scriptNeedsReload.set(reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
scriptNeedsReload.set(!reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
||||||
} else {
|
} else {
|
||||||
scriptNeedsReload.set(reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
scriptNeedsReload.set(!reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,9 +78,9 @@ public class ScriptedRulesEngine extends AbstractScriptedControllerService imple
|
||||||
public void setup() {
|
public void setup() {
|
||||||
if (scriptNeedsReload.get() || rulesEngine.get() == null) {
|
if (scriptNeedsReload.get() || rulesEngine.get() == null) {
|
||||||
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
||||||
scriptNeedsReload.set(reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
scriptNeedsReload.set(!reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
||||||
} else {
|
} else {
|
||||||
scriptNeedsReload.set(reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
scriptNeedsReload.set(!reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -80,9 +80,9 @@ public class ScriptedActionHandler extends AbstractScriptedControllerService imp
|
||||||
public void setup() {
|
public void setup() {
|
||||||
if (scriptNeedsReload.get() || actionHandler.get() == null) {
|
if (scriptNeedsReload.get() || actionHandler.get() == null) {
|
||||||
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
if (ScriptingComponentHelper.isFile(scriptingComponentHelper.getScriptPath())) {
|
||||||
scriptNeedsReload.set(reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
scriptNeedsReload.set(!reloadScriptFile(scriptingComponentHelper.getScriptPath()));
|
||||||
} else {
|
} else {
|
||||||
scriptNeedsReload.set(reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
scriptNeedsReload.set(!reloadScriptBody(scriptingComponentHelper.getScriptBody()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,8 +46,11 @@ import static org.junit.jupiter.api.Assertions.assertTrue
|
||||||
*/
|
*/
|
||||||
class TestScriptedLookupService {
|
class TestScriptedLookupService {
|
||||||
private static final String GROOVY_SCRIPT = "test_lookup_inline.groovy"
|
private static final String GROOVY_SCRIPT = "test_lookup_inline.groovy"
|
||||||
|
private static final String ALTERNATE_GROOVY_SCRIPT = "test_simple_lookup_inline.groovy"
|
||||||
private static final Path SOURCE_PATH = Paths.get("src/test/resources/groovy", GROOVY_SCRIPT)
|
private static final Path SOURCE_PATH = Paths.get("src/test/resources/groovy", GROOVY_SCRIPT)
|
||||||
|
private static final Path ALTERNATE_SOURCE_PATH = Paths.get("src/test/resources/groovy", ALTERNATE_GROOVY_SCRIPT)
|
||||||
private static final Path TARGET_PATH = Paths.get("target", GROOVY_SCRIPT)
|
private static final Path TARGET_PATH = Paths.get("target", GROOVY_SCRIPT)
|
||||||
|
private static final Path ALTERNATE_TARGET_PATH = Paths.get("target", ALTERNATE_GROOVY_SCRIPT)
|
||||||
private static final Logger logger = LoggerFactory.getLogger(TestScriptedLookupService)
|
private static final Logger logger = LoggerFactory.getLogger(TestScriptedLookupService)
|
||||||
ScriptedLookupService scriptedLookupService
|
ScriptedLookupService scriptedLookupService
|
||||||
def scriptingComponent
|
def scriptingComponent
|
||||||
|
@ -59,7 +62,9 @@ class TestScriptedLookupService {
|
||||||
logger.info("[${name?.toUpperCase()}] ${(args as List).join(" ")}")
|
logger.info("[${name?.toUpperCase()}] ${(args as List).join(" ")}")
|
||||||
}
|
}
|
||||||
Files.copy(SOURCE_PATH, TARGET_PATH, StandardCopyOption.REPLACE_EXISTING)
|
Files.copy(SOURCE_PATH, TARGET_PATH, StandardCopyOption.REPLACE_EXISTING)
|
||||||
|
Files.copy(ALTERNATE_SOURCE_PATH, ALTERNATE_TARGET_PATH, StandardCopyOption.REPLACE_EXISTING)
|
||||||
TARGET_PATH.toFile().deleteOnExit()
|
TARGET_PATH.toFile().deleteOnExit()
|
||||||
|
ALTERNATE_TARGET_PATH.toFile().deleteOnExit()
|
||||||
}
|
}
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
|
@ -96,6 +101,40 @@ class TestScriptedLookupService {
|
||||||
assertFalse(opt.present)
|
assertFalse(opt.present)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void testLookupServiceScriptReload() {
|
||||||
|
final TestRunner runner = TestRunners.newTestRunner(new AbstractProcessor() {
|
||||||
|
@Override
|
||||||
|
public void onTrigger(final ProcessContext context, final ProcessSession session) throws ProcessException {
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
runner.addControllerService("lookupService", scriptedLookupService)
|
||||||
|
runner.setProperty(scriptedLookupService, "Script Engine", "Groovy")
|
||||||
|
runner.setProperty(scriptedLookupService, ScriptingComponentUtils.SCRIPT_BODY, (String) null)
|
||||||
|
runner.setProperty(scriptedLookupService, ScriptingComponentUtils.SCRIPT_FILE, ALTERNATE_TARGET_PATH.toString())
|
||||||
|
runner.setProperty(scriptedLookupService, ScriptingComponentUtils.MODULES, (String) null)
|
||||||
|
// This call to setup should fail loading the script but should mark that the script should be reloaded
|
||||||
|
scriptedLookupService.setup()
|
||||||
|
// This prevents the (lookupService == null) check from passing, in order to force the reload from the
|
||||||
|
// scriptNeedsReload variable specifically
|
||||||
|
scriptedLookupService.lookupService.set(new MockScriptedLookupService())
|
||||||
|
|
||||||
|
runner.enableControllerService(scriptedLookupService)
|
||||||
|
|
||||||
|
MockFlowFile mockFlowFile = new MockFlowFile(1L)
|
||||||
|
InputStream inStream = new ByteArrayInputStream('Flow file content not used'.bytes)
|
||||||
|
|
||||||
|
Optional opt = scriptedLookupService.lookup(['key':'Hello'])
|
||||||
|
assertTrue(opt.present)
|
||||||
|
assertEquals('Hi', opt.get())
|
||||||
|
opt = scriptedLookupService.lookup(['key':'World'])
|
||||||
|
assertTrue(opt.present)
|
||||||
|
assertEquals('there', opt.get())
|
||||||
|
opt = scriptedLookupService.lookup(['key':'Not There'])
|
||||||
|
assertFalse(opt.present)
|
||||||
|
}
|
||||||
|
|
||||||
class MockScriptedLookupService extends ScriptedLookupService implements AccessibleScriptingComponentHelper {
|
class MockScriptedLookupService extends ScriptedLookupService implements AccessibleScriptingComponentHelper {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue