diff options
Diffstat (limited to 'gvnfmadapter')
-rw-r--r-- | gvnfmadapter/driver/interfaces/tests.py | 98 | ||||
-rw-r--r-- | gvnfmadapter/driver/interfaces/views.py | 87 |
2 files changed, 90 insertions, 95 deletions
diff --git a/gvnfmadapter/driver/interfaces/tests.py b/gvnfmadapter/driver/interfaces/tests.py index a05ea80..68e84b5 100644 --- a/gvnfmadapter/driver/interfaces/tests.py +++ b/gvnfmadapter/driver/interfaces/tests.py @@ -31,27 +31,26 @@ class InterfacesTest(TestCase): def test_instantiate_vnf(self, mock_call_req): vnfm_info = { 'userName': 'admin', - 'vendor': 'ZTE', - 'name': 'ZTE_VNFM_237_62', - 'vimId': '516cee95-e8ca-4d26-9268-38e343c2e31e', - 'url': 'http://192.168.237.165:2324', - 'certificateUrl': '', - 'version': 'V1.0', - 'vnfmId': 'b0797c9b-3da9-459c-b25c-3813e9d8fd70', - 'password': 'admin', - 'type': 'ztevmanagerdriver', - 'createTime': '2016-10-31 11:08:39', - 'description': '' + 'vendor': 'ZTE', + 'name': 'ZTE_VNFM_237_62', + 'vimId': '516cee95-e8ca-4d26-9268-38e343c2e31e', + 'url': 'http: //192.168.237.165: 2324', + 'certificateUrl': '', + 'version': 'V1.0', + 'vnfmId': 'b0797c9b-3da9-459c-b25c-3813e9d8fd70', + 'password': 'admin', + 'type': 'ztevmanagerdriver', + 'createTime': '2016-10-3111: 08: 39', + 'description': '' } job_info = { - "vnfInstanceId":"8", - "jobId":"NF-CREATE-8-b384535c-9f45-11e6-8749-fa163e91c2f9" + "vnfInstanceId": "8", + "jobId": "NF-CREATE-8-b384535c-9f45-11e6-8749-fa163e91c2f9" } vnflcm_info = { - "vnfInstanceId":"8", - "vnfLcOpId":"NF-INST-8-6ffa8083-6705-49b3-ae54-cbd6265fbe7a" + "vnfInstanceId": "8", + "vnfLcOpId": "NF-INST-8-6ffa8083-6705-49b3-ae54-cbd6265fbe7a" } - r1 = [0, json.JSONEncoder().encode(vnfm_info), "200"] ret = [0, json.JSONEncoder().encode(job_info), '200'] ret2 = [0, json.JSONEncoder().encode(vnflcm_info), '200'] @@ -69,7 +68,7 @@ class InterfacesTest(TestCase): 'externalManageNetworkName': 'mng_net_2017', 'sfc_data_network': 'sfc_data_net_2016', 'externalDataNetworkName': 'Flow_out_net', - 'inputs':{} + 'inputs': {} } } response = self.client.post("/api/gvnfmdriver/v1/1/vnfs", @@ -98,7 +97,6 @@ class InterfacesTest(TestCase): "createTime": "2016-07-06 15:33:18" } job_info = {"vnfInstanceId": "1", "vnfLcOpId": "1"} - # job_status_info = {"responseDescriptor":{"progress":"100"}} job_status_info = { "jobId": "1", "responseDescriptor": { @@ -142,47 +140,59 @@ class InterfacesTest(TestCase): "password": "admin", "createTime": "2016-07-06 15:33:18" } - job_info = {"ResponseInfo": {"vnfInstanceId":"88","instantiationState":"INSTANTIATED","vnfSoftwareVersion":"v1.2.3"}} + job_info = { + "ResponseInfo": { + "vnfInstanceId": "88", + "instantiationState": "INSTANTIATED", + "vnfSoftwareVersion": "v1.2.3" + } + } r1 = [0, json.JSONEncoder().encode(vnfm_info), "200"] r2 = [0, json.JSONEncoder().encode(job_info), "200"] mock_call_req.side_effect = [r1, r2] response = self.client.get("/api/gvnfmdriver/v1/19ecbb3a-3242-4fa3-9926-8dfb7ddc29ee/vnfs/88") self.assertEqual(status.HTTP_200_OK, response.status_code) - expect_resp_data = {"vnfInfo": {"vnfInstanceId": "88", "vnfStatus": "ACTIVE","version":"v1.2.3"}} + expect_resp_data = { + "vnfInfo": { + "vnfInstanceId": "88", + "vnfStatus": "ACTIVE", + "version": "v1.2.3" + } + } self.assertEqual(expect_resp_data, response.data) @mock.patch.object(restcall, 'call_req') def test_operation_status(self, mock_call_req): vnfm_info = { 'userName': 'admin', - 'vendor': 'ZTE', - 'name': 'ZTE_VNFM_237_62', - 'vimId': '516cee95-e8ca-4d26-9268-38e343c2e31e', - 'url': 'http://192.168.237.165:2324', - 'certificateUrl': '', - 'version': 'V1.0', - 'vnfmId': 'b0797c9b-3da9-459c-b25c-3813e9d8fd70', - 'password': 'admin', - 'type': 'ztevmanagerdriver', - 'createTime': '2016-10-31 11:08:39', - 'description': '' + 'vendor': 'ZTE', + 'name': 'ZTE_VNFM_237_62', + 'vimId': '516cee95-e8ca-4d26-9268-38e343c2e31e', + 'url': 'http: //192.168.237.165: 2324', + 'certificateUrl': '', + 'version': 'V1.0', + 'vnfmId': 'b0797c9b-3da9-459c-b25c-3813e9d8fd70', + 'password': 'admin', + 'type': 'ztevmanagerdriver', + 'createTime': '2016-10-3111: 08: 39', + 'description': '' } expected_body = { "jobId": "NF-CREATE-11-ec6c2f2a-9f48-11e6-9405-fa163e91c2f9", - "responseDescriptor":{ + "responseDescriptor": { "responseId": 3, "progress": 40, "status": "PROCESSING", "statusDescription": "OMC VMs are decommissioned in VIM", "errorCode": "null", "responseHistoryList": [ - { - "status": "error", - "progress": 255, - "errorcode": "", - "responseid": 20, - "statusdescription": "'JsonParser' object has no attribute 'parser_info'" - } + { + "status": "error", + "progress": 255, + "errorcode": "", + "responseid": 20, + "statusdescription": "'JsonParser' object has no attribute 'parser_info'" + } ] } } @@ -207,9 +217,8 @@ class InterfacesTest(TestCase): r1 = [0, json.JSONEncoder().encode(vnfm_info), '200'] r2 = [0, json.JSONEncoder().encode(resp_body), '200'] mock_call_req.side_effect = [r1, r2] - response = self.client.get("/api/gvnfmdriver/v1/{vnfmid}/jobs/{jobid}?responseId={responseId}". - format(vnfmid=vnfm_info["vnfmId"],jobid=resp_body["ResponseInfo"]["vnfLcOpId"], - responseId=resp_body["ResponseInfo"]["responseDescriptor"]["responseId"])) + response = self.client.get("/api/gvnfmdriver/v1/%s/jobs/%s?responseId=0" + %(vnfm_info["vnfmId"], expected_body["jobId"])) self.assertEqual(status.HTTP_200_OK, response.status_code) self.assertDictEqual(expected_body, response.data) @@ -243,7 +252,7 @@ class InterfacesTest(TestCase): @mock.patch.object(restcall, 'call_req') def test_notify(self, mock_call_req): vim_info = { - "vim":{ + "vim": { "vimInfoId": "111111", "vimId": "12345678", "interfaceInfo": { @@ -295,7 +304,8 @@ class InterfacesTest(TestCase): ] } response = self.client.post("/api/gvnfmdriver/v1/vnfs/lifecyclechangesnotification", - data=json.dumps(req_data), content_type='application/json') + data=json.dumps(req_data), + content_type='application/json') self.assertEqual(str(status.HTTP_200_OK), response.status_code) expect_resp_data = None self.assertEqual(expect_resp_data, response.data) diff --git a/gvnfmadapter/driver/interfaces/views.py b/gvnfmadapter/driver/interfaces/views.py index bfb91e7..a96a510 100644 --- a/gvnfmadapter/driver/interfaces/views.py +++ b/gvnfmadapter/driver/interfaces/views.py @@ -184,20 +184,25 @@ def operation_status(request, *args, **kwargs): def grantvnf(request, *args, **kwargs): logger.info("=====grantvnf=====") try: - resp_data = {} logger.info("req_data = %s", request.data) ret = req_by_msb('api/nslcm/v1/grantvnf', "POST", content=json.JSONEncoder().encode(request.data)) logger.info("ret = %s", ret) if ret[0] != 0: - return Response(data={'error': ret[1]}, status=ret[2]) + logger.error("Status code is %s, detail is %s.", ret[2], ret[1]) + raise GvnfmDriverException('Failed to grant vnf.') resp = json.JSONDecoder().decode(ret[1]) - resp_data['vimid'] = ignorcase_get(resp['vim'], 'vimid') - resp_data['tenant'] = ignorcase_get(ignorcase_get(resp['vim'], 'accessinfo'), 'tenant') + resp_data = { + 'vimid': ignorcase_get(resp['vim'], 'vimid'), + 'tenant': ignorcase_get(ignorcase_get(resp['vim'], 'accessinfo'), 'tenant') + } logger.info("[%s]resp_data=%s", fun_name(), resp_data) - except Exception as e: - logger.error("Error occurred in Grant VNF.") - raise e - return Response(data=resp_data, status=ret[2]) + return Response(data=resp_data, status=ret[2]) + except GvnfmDriverException as e: + logger.error('Grant vnf failed, detail message: %s' % e.message) + return Response(data={'error': e.message}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) + except: + logger.error(traceback.format_exc()) + return Response(data={'error': 'unexpected exception'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) @api_view(http_method_names=['POST']) @@ -208,21 +213,33 @@ def notify(request, *args, **kwargs): ret = req_by_msb("api/nslcm/v1/vnfs/%s/Notify" % vnfinstanceid, "POST", json.JSONEncoder().encode(request.data)) logger.info("[%s]data = %s", fun_name(), ret) if ret[0] != 0: - return Response(data={'error': ret[1]}, status=ret[2]) - except Exception as e: - logger.error("Error occurred in LCM notification.") - raise e - return Response(data=None, status=ret[2]) + logger.error("Status code is %s, detail is %s.", ret[2], ret[1]) + raise GvnfmDriverException('Failed to notify vnf.') + return Response(data=None, status=ret[2]) + except GvnfmDriverException as e: + logger.error('Grant vnf failed, detail message: %s' % e.message) + return Response(data={'error': e.message}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) + except: + logger.error(traceback.format_exc()) + return Response(data={'error': 'unexpected exception'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) @api_view(http_method_names=['GET']) def get_vnfpkgs(request, *args, **kwargs): - logger.info("Enter %s", fun_name()) - ret = req_by_msb("api/nslcm/v1/vnfpackage", "GET") - if ret[0] != 0: - return Response(data={'error': ret[1]}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) - resp = json.JSONDecoder().decode(ret[1]) - return Response(data=resp, status=status.HTTP_200_OK) + try: + logger.info("Enter %s", fun_name()) + ret = req_by_msb("api/nslcm/v1/vnfpackage", "GET") + if ret[0] != 0: + logger.error("Status code is %s, detail is %s.", ret[2], ret[1]) + raise GvnfmDriverException('Failed to get vnfpkgs.') + resp = json.JSONDecoder().decode(ret[1]) + return Response(data=resp, status=status.HTTP_200_OK) + except GvnfmDriverException as e: + logger.error('Get vnfpkgs failed, detail message: %s' % e.message) + return Response(data={'error': e.message}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) + except: + logger.error(traceback.format_exc()) + return Response(data={'error': 'unexpected exception'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR) def call_vnfm(resource, method, vnfm_info, data=""): @@ -273,37 +290,6 @@ def get_vnfminfo_from_nslcm(vnfm_id): return json.JSONDecoder().decode(ret[1]) -# def wait4job(vnfm_id, jobId, gracefulTerminationTimeout): -# begin_time = time.time() -# try: -# logger.debug("[wait4job] vnfm_id=[%s],jobId=[%s],gracefulTerminationTimeout=[%s]", -# vnfm_id, jobId, gracefulTerminationTimeout) -# vnfm_info = get_vnfminfo_from_nslcm(vnfm_id) -# logger.debug("[do_terminatevnf] vnfm_info=[%s]", vnfm_info) -# -# ret, vnfm_info = get_vnfminfo_from_nslcm(vnfm_id) -# if ret != 0: -# return 255, Response(data={"error":"Fail to get VNFM!"}, status=status.HTTP_412_PRECONDITION_FAILED) -# -# responseId = None -# while ret == 0: -# cur_time = time.time() -# if gracefulTerminationTimeout and (cur_time - begin_time > gracefulTerminationTimeout): -# return 255, Response(data={"error":"Fail to terminate VNF!"}, status=status.HTTP_408_REQUEST_TIMEOUT) -# ret = call_vnfm("api/vnflcm/v1/vnf_lc_ops/%s?responseId=%s" % (jobId, responseId), "GET", vnfm_info) -# if ret[0] != 0: -# return 255, Response(data={"error":"Fail to get job status!"}, status=status.HTTP_412_PRECONDITION_FAILED) -# if json.JSONDecoder().decode(ret[2]) != 200: -# return 255, Response(data={"error":"Fail to get job status!"}, status=status.HTTP_412_PRECONDITION_FAILED) -# job_info = json.JSONDecoder().decode(ret[1]) -# responseId = ignorcase_get(ignorcase_get(job_info, "VnfLcOpResponseDescriptor"), "responseId") -# progress = ignorcase_get(ignorcase_get(job_info, "VnfLcOpResponseDescriptor"), "progress") -# if progress == "100": -# return 0, Response(data={"success":"success"}, status=status.HTTP_204_NO_CONTENT) -# except Exception as e: -# logger.error("Error occurred when do_createvnf") -# return 255, Response(data={"error":"Exception caught! Fail to get job status!"}, status=status.HTTP_412_PRECONDITION_FAILED) - def wait4job(vnfm_id, job_id, gracefulTerminationTimeout=1200, retry_count=60, interval_second=3): logger.debug("[wait4job] vnfm_id=[%s],jobId=[%s],gracefulTerminationTimeout=[%s]", vnfm_id, job_id, gracefulTerminationTimeout) @@ -312,7 +298,6 @@ def wait4job(vnfm_id, job_id, gracefulTerminationTimeout=1200, retry_count=60, i job_end_normal, job_timeout = False, True vnfm_info = get_vnfminfo_from_nslcm(vnfm_id) logger.debug("[do_terminatevnf] vnfm_info=[%s]", vnfm_info) - while count < retry_count: count = count + 1 time.sleep(interval_second) |