diff options
author | 2022-10-21 17:36:17 +0200 | |
---|---|---|
committer | 2022-10-21 17:36:33 +0200 | |
commit | 5762244a0c6282557169c8183e464f6950438122 (patch) | |
tree | d1b1a4a18edc72918be8bb2f6f4b7a1ad104abce /tutorials/ApacheCNF/automation | |
parent | 0c85ee9fc85870f8ba39befc63b8351301d4842f (diff) |
[APACHECNF] Update healthcheck and add scale workflow
Issue-ID: INT-2164
Signed-off-by: Lukasz Rajewski <lukasz.rajewski@t-mobile.pl>
Change-Id: I7cf59f58592321ec06d8d812bd081293130ec74d
Diffstat (limited to 'tutorials/ApacheCNF/automation')
-rw-r--r-- | tutorials/ApacheCNF/automation/README.md | 7 | ||||
-rw-r--r-- | tutorials/ApacheCNF/automation/healthcheck.py | 13 | ||||
-rw-r--r-- | tutorials/ApacheCNF/automation/scale.py | 100 |
3 files changed, 115 insertions, 5 deletions
diff --git a/tutorials/ApacheCNF/automation/README.md b/tutorials/ApacheCNF/automation/README.md index 5b2b80b3..66138c98 100644 --- a/tutorials/ApacheCNF/automation/README.md +++ b/tutorials/ApacheCNF/automation/README.md @@ -28,5 +28,8 @@ 8. Run script `python create_cloud_regions.py` in order to create **k8s or openstack cloud region** 9. Onboard CNF `python onboard.py` 10. Instantiate CNF `python instantiate.py` -11. Once test is done, CNF service instance can be deleted with `python delete.py` command - +11. To run healtcheck operation execute `python healthcheck.py <status_check_max_count>` where <status_check_max_count> [int] (default 1) + indicates iteration number to run status check in case of failure +12. To run scale operation execute `python scale.py <replica_count>` where <replica_count> [int] (default 1) + indicates the number of desired replicas of Apache pods +13. Once test is done, CNF service instance can be deleted with `python delete.py` command diff --git a/tutorials/ApacheCNF/automation/healthcheck.py b/tutorials/ApacheCNF/automation/healthcheck.py index 9c33375e..6fe72397 100644 --- a/tutorials/ApacheCNF/automation/healthcheck.py +++ b/tutorials/ApacheCNF/automation/healthcheck.py @@ -1,5 +1,6 @@ # ============LICENSE_START======================================================= # Copyright (C) 2021 Samsung +# Modification Copyright (C) 2022 Deutsche Telekom AG # ================================================================================ # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -16,6 +17,7 @@ # ============LICENSE_END========================================================= import logging import os +import sys import zipfile from io import BytesIO @@ -61,7 +63,7 @@ def resolve_hc_inputs(config: Config): vnf_id = vnfs[0].vnf_id return service_id, vnf_id -def main(): +def main(status_count): mypath = os.path.dirname(os.path.realpath(__file__)) config = Config(env_dict=VariablesDict.env_variable) for vnf in config.service_model["vnfs"]: @@ -77,7 +79,8 @@ def main(): cds_input = {"health-check-properties": { "service-instance-id": serv_id, - "vnf-id": vnf_id + "vnf-id": vnf_id, + "status-check-max-count": int(status_count) } } @@ -90,4 +93,8 @@ def main(): logger.info("Please check cds-blueprints-processor logs to see exact status") if __name__ == "__main__": - main() + status_count = 1 + if len(sys.argv) > 1: + status_count = sys.argv[1] + print(f"Status Check Max Count: %s" % status_count) + main(status_count) diff --git a/tutorials/ApacheCNF/automation/scale.py b/tutorials/ApacheCNF/automation/scale.py new file mode 100644 index 00000000..e4623f41 --- /dev/null +++ b/tutorials/ApacheCNF/automation/scale.py @@ -0,0 +1,100 @@ +# ============LICENSE_START======================================================= +# Copyright (C) 2022 Deutsche Telekom AG +# ================================================================================ +# 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. +# +# ============LICENSE_END========================================================= +import logging +import os +import sys +import zipfile +from io import BytesIO + +from onapsdk.aai.business import Customer +from onapsdk.cds.blueprint import Workflow, Blueprint +from config import Config, VariablesDict + +#FIXME remove from global scope +logger = logging.getLogger("") +logger.setLevel(logging.INFO) +fh = logging.StreamHandler() +fh_formatter = logging.Formatter('%(asctime)s %(levelname)s %(lineno)d:%(filename)s(%(process)d) - %(message)s') +fh.setFormatter(fh_formatter) +logger.addHandler(fh) + + +def resolve_inputs(config: Config): + logger.info("******** Check Customer *******") + customer_id = config.service_instance["customer_id"] + customer = Customer.get_by_global_customer_id(customer_id) + if customer is None: + raise Exception("Customer %s wasn't found in ONAP" % customer_id) + logger.info("******** Check Service Subscription *******") + service_subscription = None + for service_sub in customer.service_subscriptions: + logger.debug("Service subscription %s is found", service_sub.service_type) + if service_sub.service_type == config.service_model["model_name"]: + logger.info("Service %s subscribed", config.service_model["model_name"]) + service_subscription = service_sub + break + logger.info("******** Retrieve Service Metadata *******") + service_instance = None + for single_service in service_subscription.service_instances: + if single_service.instance_name == config.service_instance["instance_name"]: + service_instance = single_service + break + service_id = service_instance.instance_id + vnfs = list(service_instance.vnf_instances) + if len(vnfs) > 1: + raise NotImplementedError("Service %s is composed of more than one vnf!" % service_id) + if not vnfs: + raise Exception("Service %s doesn't contain any vnfs" % service_id) + vnf_id = vnfs[0].vnf_id + return service_id, vnf_id + +def main(replica_count): + mypath = os.path.dirname(os.path.realpath(__file__)) + config = Config(env_dict=VariablesDict.env_variable) + for vnf in config.service_model["vnfs"]: + file = vnf["vsp"]["vsp_file"] + file_path = os.path.join(mypath, file) + with zipfile.ZipFile(file_path, 'r') as package: + cba_io = BytesIO(package.read("CBA.zip")) + cba_io.seek(0) + blueprint = Blueprint(cba_io.read()) + + healthcheck: Workflow = blueprint.get_workflow_by_name('scale') + serv_id, vnf_id = resolve_inputs(config) + cds_input = {"scale-properties": + { + "service-instance-id": serv_id, + "vnf-id": vnf_id, + "status-check-max-count": 20, + "replica-count": int(replica_count) + } + } + + logger.info("Requesting Scale for CBA %s:%s with inputs:\n%s", + blueprint.metadata.template_name, + blueprint.metadata.template_version, + cds_input) + result = healthcheck.execute(cds_input) + logger.info("Scale process completed with result: %s", result) + logger.info("Please check cds-blueprints-processor logs to see exact status") + +if __name__ == "__main__": + replica_count = 1 + if len(sys.argv) > 1: + replica_count = sys.argv[1] + print(f"Replica Count: %s" % replica_count) + main(replica_count) |