From e92fce768cb792f11920f45fdbb38b3af69e212f Mon Sep 17 00:00:00 2001 From: Jozsef Csongvai Date: Tue, 19 Jan 2021 12:32:04 -0500 Subject: Update to latest version Issue-ID: TEST-295 Signed-off-by: Jozsef Csongvai Change-Id: Ie14e2061c1e0931bf3d555e54c79bb736d140d5c --- cba/py-executor/.DS_Store | Bin 0 -> 6148 bytes cba/py-executor/Definitions/py-executor.json | 174 +++++++++++++++++++++++ cba/py-executor/Scripts/python/__init__.py | 18 +++ cba/py-executor/Scripts/python/failing_script.py | 34 +++++ cba/py-executor/Scripts/python/hello_world.py | 42 ++++++ cba/py-executor/TOSCA-Metadata/TOSCA.meta | 8 ++ 6 files changed, 276 insertions(+) create mode 100644 cba/py-executor/.DS_Store create mode 100644 cba/py-executor/Definitions/py-executor.json create mode 100644 cba/py-executor/Scripts/python/__init__.py create mode 100644 cba/py-executor/Scripts/python/failing_script.py create mode 100644 cba/py-executor/Scripts/python/hello_world.py create mode 100644 cba/py-executor/TOSCA-Metadata/TOSCA.meta (limited to 'cba/py-executor') diff --git a/cba/py-executor/.DS_Store b/cba/py-executor/.DS_Store new file mode 100644 index 0000000..cd1acc1 Binary files /dev/null and b/cba/py-executor/.DS_Store differ diff --git a/cba/py-executor/Definitions/py-executor.json b/cba/py-executor/Definitions/py-executor.json new file mode 100644 index 0000000..7d9755b --- /dev/null +++ b/cba/py-executor/Definitions/py-executor.json @@ -0,0 +1,174 @@ +{ + "metadata": { + "template_author": "Selffish", + "author-email": "test@bell.ca", + "template_name": "RT-py-executor", + "template_version": "1.0.0", + "template_tags": "Bell, CBA, test" + }, + "dsl_definitions": { + "py-executor": { + "type": "tls-auth", + "host": .PY_EXEC_SVC, + "port": "50052", + "trustCertCollection": "/opt/app/onap/config/certs/py-executor/py-executor-chain.pem" + }, + "invalid-py-executor": { + "type": "tls-auth", + "host": "127.0.0.1", + "port": "12345", + "trustCertCollection": "/opt/app/onap/config/certs/py-executor/py-executor-chain.pem" + }, + "parameters": { + "hello" : "world" + } + }, + "topology_template": { + "workflows": { + "remote-python": { + "steps": { + "execute-script": { + "description": "Execute Remote Python Script", + "target": "execute-remote-python" + } + }, + "inputs": {}, + "outputs": { + "status": { + "type": "string", + "value": { + "get_attribute": [ + "execute-remote-python", + "status" + ] + } + }, + "response-data": { + "type": "json", + "value": { + "get_attribute": [ + "execute-remote-python", + "response-data" + ] + } + } + } + }, + "connection-fail": { + "steps": { + "execute-script": { + "description": "Execute Remote Python Script to an invalid endpoint", + "target": "execute-connection-fail" + } + }, + "inputs": {}, + "outputs": { + "status": { + "type": "string", + "value": { + "get_attribute": [ + "execute-connection-fail", + "status" + ] + } + }, + "response-data": { + "type": "json", + "value": { + "get_attribute": [ + "execute-connection-fail", + "response-data" + ] + } + } + } + }, + "failing-remote-python": { + "steps": { + "execute-script": { + "description": "Execute Remote Python Script", + "target": "execute-failing-remote-python" + } + }, + "inputs": {}, + "outputs": { + "status": { + "type": "string", + "value": { + "get_attribute": [ + "execute-failing-remote-python", + "status" + ] + } + }, + "response-data": { + "type": "json", + "value": { + "get_attribute": [ + "execute-failing-remote-python", + "response-data" + ] + } + } + } + } + }, + "node_templates": { + "execute-remote-python": { + "type": "component-remote-script-executor", + "interfaces": { + "ComponentRemoteScriptExecutor": { + "operations": { + "process": { + "inputs": { + "selector": "*py-executor", + "blueprint-name": "RT-py-executor", + "blueprint-version": "1.0.0", + "blueprint-action": "HelloWorld", + "timeout": 1000, + "request-data": "*parameters" + } + } + } + } + } + }, + "execute-connection-fail": { + "type": "component-remote-script-executor", + "interfaces": { + "ComponentRemoteScriptExecutor": { + "operations": { + "process": { + "inputs": { + "selector": "*invalid-py-executor", + "blueprint-name": "RT-py-executor", + "blueprint-version": "1.0.0", + "blueprint-action": "HelloWorld", + "timeout": 1000 + } + } + } + } + } + }, + "execute-failing-remote-python": { + "type": "component-remote-script-executor", + "interfaces": { + "ComponentRemoteScriptExecutor": { + "operations": { + "process": { + "inputs": { + "selector": "*py-executor", + "blueprint-name": "RT-py-executor", + "blueprint-version": "1.0.0", + "blueprint-action": "FailingScript", + "timeout": 1000 + } + } + } + } + } + } + } + } +} diff --git a/cba/py-executor/Scripts/python/__init__.py b/cba/py-executor/Scripts/python/__init__.py new file mode 100644 index 0000000..0c354d8 --- /dev/null +++ b/cba/py-executor/Scripts/python/__init__.py @@ -0,0 +1,18 @@ +# +# Copyright © 2020 Bell Canada. +# +# Licensed 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. +# + +from .hello_world import * +from .failing_script import * diff --git a/cba/py-executor/Scripts/python/failing_script.py b/cba/py-executor/Scripts/python/failing_script.py new file mode 100644 index 0000000..e7a8802 --- /dev/null +++ b/cba/py-executor/Scripts/python/failing_script.py @@ -0,0 +1,34 @@ +#!/usr/bin/python +# +# Copyright © 2020 Bell Canada. +# +# Licensed 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. +# + +import logging +from blueprints_grpc import executor_utils +from blueprints_grpc.blueprint_processing_server import AbstractScriptFunction + +class FailingScript(AbstractScriptFunction): + def __init__(self): + self.logger = logging.getLogger(self.__class__.__name__) + + def process(self, execution_request): + self.logger.info("Request Received in Script : {}".format(execution_request)) + raise RuntimeError('Script raised an exception') + + def recover(self, runtime_exception, execution_request): # Ignore PyLintBear (W0613) + return None + + def send_notification(self, execution_request): + yield executor_utils.send_notification(execution_request, "I am notification") diff --git a/cba/py-executor/Scripts/python/hello_world.py b/cba/py-executor/Scripts/python/hello_world.py new file mode 100644 index 0000000..1500a3c --- /dev/null +++ b/cba/py-executor/Scripts/python/hello_world.py @@ -0,0 +1,42 @@ +#!/usr/bin/python +# +# Copyright © 2020 Bell Canada. +# +# Licensed 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. +# + +import logging +from blueprints_grpc import executor_utils +from blueprints_grpc.blueprint_processing_server import AbstractScriptFunction +import json +from google.protobuf import json_format + +class HelloWorld(AbstractScriptFunction): + def __init__(self): + self.logger = logging.getLogger(self.__class__.__name__) + + def process(self, execution_request): + self.logger.info("Request Received in Script : {}".format(execution_request)) + + inputs = json_format.MessageToJson(execution_request.payload) + response_payload_json = json.loads(inputs) + + execution_response = executor_utils.success_response(execution_request, response_payload_json, 200) + self.logger.info("Response returned : {}".format(execution_response)) + yield execution_response + + def recover(self, runtime_exception, execution_request): # Ignore PyLintBear (W0613) + return None + + def send_notification(self, execution_request): + yield executor_utils.send_notification(execution_request, "I am notification") diff --git a/cba/py-executor/TOSCA-Metadata/TOSCA.meta b/cba/py-executor/TOSCA-Metadata/TOSCA.meta new file mode 100644 index 0000000..8389ebb --- /dev/null +++ b/cba/py-executor/TOSCA-Metadata/TOSCA.meta @@ -0,0 +1,8 @@ +TOSCA-Meta-File-Version: 1.0.0 +CSAR-Version: 1.0 +Created-By: Selffish +Entry-Definitions: Definitions/py-executor.json +Template-Tags: test, regression +Template-Name: RT-py-executor +Template-Version: 1.0.0 +Template-Type: DEFAULT -- cgit 1.2.3-korg