diff options
author | Haibin Huang <haibin.huang@intel.com> | 2019-05-09 14:36:05 +0800 |
---|---|---|
committer | Haibin Huang <haibin.huang@intel.com> | 2019-05-09 14:42:19 +0800 |
commit | 9b51423f989c895744e983e3a76718fb3112415b (patch) | |
tree | 17aa2be95d896deff207285e5a8bb6839b613f64 /test/hpa_automation/tosca | |
parent | e4f5dda0ea994e926da0a40febf4e489b7a68626 (diff) |
Add E2E automation test vcpe
Change-Id: I73ab75ee9321c8b360745a963f28b0a869a279ea
Issue-ID: INT-795
Signed-off-by: Haibin Huang <haibin.huang@intel.com>
Diffstat (limited to 'test/hpa_automation/tosca')
-rwxr-xr-x | test/hpa_automation/tosca/hpa_automation.py | 183 | ||||
-rwxr-xr-x | test/hpa_automation/tosca/vcpe_config.json | 139 |
2 files changed, 322 insertions, 0 deletions
diff --git a/test/hpa_automation/tosca/hpa_automation.py b/test/hpa_automation/tosca/hpa_automation.py new file mode 100755 index 000000000..ff53303bc --- /dev/null +++ b/test/hpa_automation/tosca/hpa_automation.py @@ -0,0 +1,183 @@ +#!/usr/bin/python + +#Prerequisites for machine to run this +#Put in required parameters in hpa_automation_config.json +#Install python-pip (apt install python-pip) +#Install python mysql.connector (pip install mysql-connector-python) +#Install ONAP CLI +#Must have connectivity to the ONAP, a k8s vm already running is recommended +#Create Preload File, the script will modify the parameters required from serivce model, service instance +#and vnf instance +#Create policies for homing +#Put in CSAR file +#modify so-bpmn configmap and change version to v2 + +import json +import os +import time +import argparse +import sys + +def get_parameters(file): + parameters = json.load(file) + return parameters + +def get_out_helper(in_string): + out_list = (((in_string.replace('-','')).replace('|', '')).replace('+', '')).split() + return out_list + +def get_out_helper_2(in_string): + out_list = ((in_string.replace('|', '')).replace('+', '')).split() + return out_list + +def set_open_cli_env(parameters): + os.environ["OPEN_CLI_PRODUCT_IN_USE"] = parameters["open_cli_product"] + os.environ["OPEN_CLI_HOME"] = parameters["open_cli_home"] + +def create_complex(parameters): + complex_create_string = "oclip complex-create -j {} -r {} -x {} -y {} -lt {} -l {} -i {} -lo {} \ + -S {} -la {} -g {} -w {} -z {} -k {} -o {} -q {} -m {} -u {} -p {}".format(parameters["street2"], \ + parameters["physical_location"], parameters["complex_name"], \ + parameters["data_center_code"], parameters["latitude"], parameters["region"], \ + parameters["street1"], parameters["longitude"], parameters["state"], \ + parameters["lata"], parameters["city"], parameters["postal-code"], \ + parameters["complex_name"], parameters["country"], parameters["elevation"], \ + parameters["identity_url"], parameters["aai_url"], parameters["aai_username"], \ + parameters["aai_password"]) + + os.system(complex_create_string) + + +def register_cloud_helper(cloud_region, values, parameters): + #Create Cloud + cloud_create_string = 'oclip cloud-create -e {} -b {} -I {{\\\\\\"openstack-region-id\\\\\\":\\\\\\"{}\\\\\\"}} \ + -x {} -y {} -j {} -w {} -l {} -url {} -n {} -q {} -r {} -Q {} -i {} -g {} -z {} -k {} -c {} -m {} -u {} -p {}'.format( + values.get("esr-system-info-id"), values.get("user-name"), cloud_region, parameters["cloud-owner"], \ + cloud_region, values.get("password"), values.get("cloud-region-version"), values.get("default-tenant"), \ + values.get("service-url"), parameters["complex_name"], values.get("cloud-type"), parameters["owner-defined-type"], \ + values.get("system-type"), values.get("identity-url"), parameters["cloud-zone"], values.get("ssl-insecure"), \ + values.get("system-status"), values.get("cloud-domain"), parameters["aai_url"], parameters["aai_username"], \ + parameters["aai_password"]) + + + os.system(cloud_create_string) + + #Associate Cloud with complex + complex_associate_string = "oclip complex-associate -x {} -y {} -z {} -m {} -u {} -p {}".format(parameters["complex_name"], \ + cloud_region, parameters["cloud-owner"], parameters["aai_url"], parameters["aai_username"], parameters["aai_password"]) + os.system(complex_associate_string) + + #Register Cloud with Multicloud + multicloud_register_string = "oclip multicloud-register-cloud -y {} -x {} -m {}".format(parameters["cloud-owner"], \ + cloud_region, parameters["multicloud_url"]) + os.system(multicloud_register_string) + +def register_all_clouds(parameters): + cloud_dictionary = parameters["cloud_region_data"] + for cloud_region, cloud_region_values in cloud_dictionary.iteritems(): + register_cloud_helper(cloud_region, cloud_region_values, parameters) + +#VNF Deployment Section +def add_policies(parameters): + resource_string = (os.popen("oclip get-resource-module-name -u {} -p {} -m {} |grep {}".format(\ + parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_catalog_url"], \ + parameters["service-model-name"] ))).read() + resource_module_name = (get_out_helper_2(resource_string))[1] + + #Put in the right resource module name in all policies located in parameters["policy_directory"] + os.system("find {}/ -type f -exec sed -i 's/{}/{}/g' {{}} \;".format( + parameters["policy_directory"], parameters["temp_resource_module_name"], resource_module_name)) + + #Upload policy models + for model in os.listdir(parameters["policy_models_directory"]): + os.system("oclip policy-type-create -x {} -u {} -p {} -m {}".format(model, parameters["policy_username"], \ + parameters["policy_password"], parameters["policy_url"])) + time.sleep(0.5) + + #print("Put in the resourceModuleName {} in your policy files in {}. ".format(resource_module_name, \ + #(parameters["policy_directory"]))) + #raw_input("Press Enter to continue...") + + + #Loop through policy, put in resource_model_name and create policies + for policy in os.listdir(parameters["policy_directory"]): + policy_name = "{}.{}".format(parameters["policy_scope"], os.path.splitext(policy)[0]) + policy_file = (os.path.join(parameters["policy_directory"], policy)) + #Create policy + os.system("oclip policy-create-outdated -m {} -u {} -p {} -x {} -S {} -T {} -o {} -b $(cat {})".format(parameters["policy_url"],\ + parameters["policy_username"], parameters["policy_password"], policy_name, parameters["policy_scope"], \ + parameters["policy_config_type"], parameters["policy_onapName"], policy_file)) + + #Push policy + os.system("oclip policy-push-outdated -m {} -u {} -p {} -x {} -b {} -c {}".format(parameters["policy_url"], \ + parameters["policy_username"], parameters["policy_password"], policy_name, parameters["policy_config_type"],\ + parameters["policy_pdp_group"])) + +def onboard_vnf(parameters): + ns_csars = parameters["vnd-csars"] + vnf_onboard_outs = {} + + for key, value in ns_csars.items(): + vnf_onboard_string = 'oclip vfc-catalog-onboard-vnf -c {}'.format(value) + vnf_onboard_outs["key"] = (os.popen(ns_onboard_string)).read() + return vnf_onboard_outs + +def onboard_ns(parameters): + ns_onboard_string = 'oclip vfc-catalog-onboard-ns -c {}'.format(parameters["ns-csar-id"]) + ns_onboard_out = (os.popen(ns_onboard_string)).read() + return ns_onboard_out + +def create_ns(parameters): + ns_create_string = 'oclip vfc-nslcm-create -c {} -n {}'.format(parameters["ns-csar-id"], \ + parameters["ns-csar-name"]) + ns_create_out = (os.popen(ns_create_string)).read() + ns_instance_id = (get_out_helper_2(ns_create_out))[1] + ns_model_dict["vnf_instance_id"] = ns_instance_id + return ns_model_dict + +def instantiate_ns(parameters, ns_model_dict): + ns_instance_id = ns_model_dict["ns_instance_id"] + ns_instantiate_string = 'oclip vfc-nslcm-instantiate -i {} -c {} -n {}'.format(ns_instance_id, \ + parameters["location-constraints"], parameters["sdc-controller-id"]) + ns_instantiate_out = (os.popen(ns_instantiate_string)).read() + return ns_instantiate_out + +#Run Functions +parser = argparse.ArgumentParser() +parser.add_argument('-f', action='store', dest='config_file_path', help='Store config file path') + +parser.add_argument('--version', action='version', version='%(prog)s 1.0') + +results = parser.parse_args() + +config_file_path = results.config_file_path +if config_file_path is None: + sys.exit(1) +config_file = open(config_file_path) +parameters = get_parameters(config_file) + +# 1.Set cli command envionment +set_open_cli_env(parameters) + +# 2.Create cloud complex +create_complex(parameters) + +# 3.FIXME:Because SDC internal API will change without notice, so I will maually design VNF and Service. +# SDC output data model is not align with VFC, we use an workaround method +# We just do run time automation + +# 4.Register all clouds +register_all_clouds(parameters) + +# 5.add_policies function not currently working, using curl commands +# add_policies(parameters) + +# 6. VFC part +vnf_onboard_output = onboard_vnf(parameters) +print vnf_onboard_output +ns_onboard_out = onboard_ns(parameters) +print ns_onboard_out +ns_model_dict = create_ns(parameters) +print ns_model_dict +instantiate_ns_output = instantiate_ns(parameters, ns_model_dict) +print instantiate_ns_output diff --git a/test/hpa_automation/tosca/vcpe_config.json b/test/hpa_automation/tosca/vcpe_config.json new file mode 100755 index 000000000..bfdbb0d6b --- /dev/null +++ b/test/hpa_automation/tosca/vcpe_config.json @@ -0,0 +1,139 @@ +{ + "open_cli_product" : "onap-dublin", + "open_cli_home" : "/root/cli/deployment/zip/target/deployunzip", + "aai_url" : "https://10.12.6.235:30233", + "aai_username" : "AAI", + "aai_password" : "AAI", + "sdc_catalog_url" : "http://10.12.6.235:30205", + "sdc_password" : "demo123456!", + "sdc_creator" : "cs0008", + + "multicloud_url" : "http://10.12.6.235:30280", + "policy_url" : "https://10.12.6.235:30240", + "policy_username" : "testpdp", + "policy_password" : "alpha123", + "policy_models_directory" : "/root/tosca/optf-osdf/osdf/models/policy/placement/tosca_upload/", + "policy_directory" : "/root/tosca/vcpe_policies", + "policy_scope" : "OSDF_DUBLIN", + "policy_onapName" : "SampleDemo", + "policy_config_type": "MicroService", + "policy_pdp_group" : "default", + "//" : "Put in a temp resource module name, should be the same in policy files, script will replace it in policies", + "temp_resource_module_name" : "resource_name", + + "//" : "#Parameters required to create cloud complex", + "complex_name" : "clli1", + "street1" : "street1", + "street2" : "street2", + "physical_location" : "phy_type", + "data_center_code" : "code1", + "latitude" : "32.89948", + "longitude" : "97.045443", + "lata" : "example-lata-val-28399", + "elevation" : "example-elevation-val-28399", + "region" : "northwest", + "state" : "oregon", + "city" : "hillsboro", + "postal-code" : "00000", + "country" : "USA", + "identity_url" : "example-identity-url-val-56898", + "service-model-name" : "vfw-hpa", + "//" : "#Dictionary containing cloud regions and their Parameters", + + "cloud_region_data":{ + "ONAP-POD-01-Rail-05":{ + "cloud-region-version" : "titanium_cloud", + "esr-system-info-id":"5c85ce1f-aa78-4ebf-8d6f-4b62784e9bc7", + "service-url": "http://10.12.11.1:5000/v3", + "user-name":"${cloud-username}", + "password":"${cloud-password}", + "system-type": "VIM", + "ssl-insecure":true, + "cloud-domain":"Default", + "default-tenant":"Integration-HPA", + "tenant-id" : "709ba629fe194f8699b12f9d6ffd86a0", + "cloud-type" : "openstack", + "identity-url": "WillBeUpdatedByMultiCloud", + "system-status":"active" + }, + "ONAP-POD-01-Rail-06":{ + "cloud-region-version" : "titanium_cloud", + "esr-system-info-id":"5c85ce1f-aa78-4ebf-8d6f-4b62773e9bc7", + "service-url": "http://10.12.11.1:5000/v3", + "user-name":"${cloud-username}", + "password":"${cloud-password}", + "system-type": "VIM", + "ssl-insecure":true, + "cloud-domain":"Default", + "default-tenant":"Integration-HPA", + "tenant-id" : "709ba629fe194f8699b12f9d6ffd86a0", + "cloud-type" : "openstack", + "identity-url": "WillBeUpdatedByMultiCloud", + "system-status":"active" + }, + "ONAP-POD-01-Rail-07":{ + "cloud-region-version" : "titanium_cloud", + "esr-system-info-id":"4c85ce1f-aa78-4ebf-8d6f-4b62773e9bc7", + "service-url": "http://10.12.11.1:5000/v3", + "user-name":"${cloud-username}", + "password":"${cloud-password}", + "system-type": "VIM", + "ssl-insecure":true, + "cloud-domain":"Default", + "default-tenant":"Integration-HPA", + "tenant-id" : "709ba629fe194f8699b12f9d6ffd86a0", + "cloud-type" : "openstack", + "identity-url": "WillBeUpdatedByMultiCloud", + "system-status":"active" + } + }, + + "//" : "#Parameters to register cloud region", + "cloud-owner" : "CloudOwner", + "owner-defined-type" : "t1", + "cloud-zone" : "CloudZone", + + "//" : "#Parameters to vfc", + "vnd-csars":{ + "vnf-vgw-csar-id": "You need change it", + "vnf-vgmux-csar-id": "You need change it", + "vnf-infra-csar-id": "You need change it", + "vnf-vbng-csar-id": "You need change it", + "vnf-vbrgemu-csar-id": "You need change it" + }, + "ns-csar-id": "You need change it", + "ns-csar-name": "vcpe", + "location-constraints":[ + { + "vnfProfileId": "3fca3543-07f5-492f-812c-ed462e4f94f4", + "locationConstraints": { + "vimId": "INTEL_ONAP-POD-01-Rail-07" + } + }, + { + "vnfProfileId": "0408f076-e6c0-4c82-9940-272fddbb82de", + "locationConstraints": { + "vimId": "INTEL_ONAP-POD-01-Rail-07" + } + }, + { + "vnfProfileId": "b1bb0ce7-2222-4fa7-95ed-4840d70a1100", + "locationConstraints": { + "vimId": "INTEL_ONAP-POD-01-Rail-07" + } + }, + { + "vnfProfileId": "b1bb0ce7-2222-4fa7-95ed-4840d70a1101", + "locationConstraints": { + "vimId": "INTEL_ONAP-POD-01-Rail-07" + } + }, + { + "vnfProfileId": "b1bb0ce7-2222-4fa7-95ed-4840d70a1102", + "locationConstraints": { + "vimId": "INTEL_ONAP-POD-01-Rail-07" + } + } + ], + "sdc-controller-id": "2" +} |