mirror of https://github.com/apache/nifi.git
NIFI-10287 ExecuteScript - Allow python scripts to use external modules
Co-authored-by: Nissim Shiman <nshiman@yahoo.com> Co-authored-by: dan-s1 <dstieg1@gmail.com> NIFI-10287 changes for code review NIFI-10287 modification based on reviewer comment Signed-off-by: Matthew Burgess <mattyb149@apache.org> This closes #6254
This commit is contained in:
parent
2afe2b36b9
commit
f4069ab77a
|
@ -265,8 +265,12 @@ public class ScriptingComponentHelper {
|
||||||
scriptEngineName = context.getProperty(SCRIPT_ENGINE).getValue();
|
scriptEngineName = context.getProperty(SCRIPT_ENGINE).getValue();
|
||||||
scriptPath = context.getProperty(ScriptingComponentUtils.SCRIPT_FILE).evaluateAttributeExpressions().getValue();
|
scriptPath = context.getProperty(ScriptingComponentUtils.SCRIPT_FILE).evaluateAttributeExpressions().getValue();
|
||||||
scriptBody = context.getProperty(ScriptingComponentUtils.SCRIPT_BODY).getValue();
|
scriptBody = context.getProperty(ScriptingComponentUtils.SCRIPT_BODY).getValue();
|
||||||
|
if ("python".equalsIgnoreCase(scriptEngineName)) {
|
||||||
|
modules = context.getProperty(ScriptingComponentUtils.MODULES).evaluateAttributeExpressions().asResources();
|
||||||
|
} else {
|
||||||
modules = context.getProperty(ScriptingComponentUtils.MODULES).evaluateAttributeExpressions().asResources().flattenRecursively();
|
modules = context.getProperty(ScriptingComponentUtils.MODULES).evaluateAttributeExpressions().asResources().flattenRecursively();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void stop() {
|
public void stop() {
|
||||||
if (scriptRunnerQ != null) {
|
if (scriptRunnerQ != null) {
|
||||||
|
|
|
@ -61,6 +61,32 @@ public class TestExecuteJython extends BaseScriptTest {
|
||||||
result.get(0).assertAttributeEquals("from-content", "test content");
|
result.get(0).assertAttributeEquals("from-content", "test content");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests a Jython script that references an outside python module
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testAccessModuleAndStoreInFlowFileAttributeWithScriptBody() {
|
||||||
|
runner.setValidateExpressionUsage(false);
|
||||||
|
runner.setProperty(scriptingComponent.getScriptingComponentHelper().SCRIPT_ENGINE, "python");
|
||||||
|
runner.setProperty(ScriptingComponentUtils.MODULES, "target/test/resources/jython/");
|
||||||
|
runner.setProperty(ScriptingComponentUtils.SCRIPT_BODY,
|
||||||
|
"from org.apache.nifi.processors.script import ExecuteScript\n"
|
||||||
|
+ "from test_external_module import ExternalModule\n"
|
||||||
|
+ "externalModule = ExternalModule()\n"
|
||||||
|
+ "flowFile = session.get()\n"
|
||||||
|
+ "flowFile = session.putAttribute(flowFile, \"key\", externalModule.testHelloWorld())\n"
|
||||||
|
+ "session.transfer(flowFile, ExecuteScript.REL_SUCCESS)");
|
||||||
|
|
||||||
|
runner.assertValid();
|
||||||
|
runner.enqueue("test content".getBytes(StandardCharsets.UTF_8));
|
||||||
|
runner.run();
|
||||||
|
|
||||||
|
runner.assertAllFlowFilesTransferred(ExecuteScript.REL_SUCCESS, 1);
|
||||||
|
final List<MockFlowFile> result = runner.getFlowFilesForRelationship(ExecuteScript.REL_SUCCESS);
|
||||||
|
result.get(0).assertAttributeEquals("key", "helloWorld");
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests a script that does not transfer or remove the original flow file, thereby causing an error during commit.
|
* Tests a script that does not transfer or remove the original flow file, thereby causing an error during commit.
|
||||||
*
|
*
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
#! /usr/bin/python
|
||||||
|
#
|
||||||
|
# Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
# or more contributor license agreements. See the NOTICE file
|
||||||
|
# distributed with this work for additional information
|
||||||
|
# regarding copyright ownership. The ASF licenses this file
|
||||||
|
# to you under the Apache License, Version 2.0 (the
|
||||||
|
# "License"); you may not use this file except in compliance
|
||||||
|
# with the License. You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing,
|
||||||
|
# software distributed under the License is distributed on an
|
||||||
|
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
# KIND, either express or implied. See the License for the
|
||||||
|
# specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
class ExternalModule :
|
||||||
|
|
||||||
|
def __init__(self) :
|
||||||
|
pass
|
||||||
|
|
||||||
|
def testHelloWorld(self) :
|
||||||
|
return "helloWorld"
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue