From 0080fa4309a40599b7d239b53bab9a74182ae500 Mon Sep 17 00:00:00 2001 From: efiacor Date: Tue, 8 Sep 2020 16:26:50 +0100 Subject: [PMSSH] Add sdnc model info to event publish Signed-off-by: efiacor Change-Id: I89e25e99a2d541a29cf4a8dde986fab5b1812c9e Issue-ID: DCAEGEN2-2405 --- .../tests/test_aai_service.py | 88 ++++++++++++++-------- 1 file changed, 58 insertions(+), 30 deletions(-) (limited to 'components/pm-subscription-handler/tests/test_aai_service.py') diff --git a/components/pm-subscription-handler/tests/test_aai_service.py b/components/pm-subscription-handler/tests/test_aai_service.py index 4b7be153..7a3b846d 100644 --- a/components/pm-subscription-handler/tests/test_aai_service.py +++ b/components/pm-subscription-handler/tests/test_aai_service.py @@ -17,40 +17,46 @@ # ============LICENSE_END===================================================== import json import os -from test.support import EnvironmentVarGuard -from unittest import mock, TestCase +from unittest import mock from unittest.mock import patch import responses -from requests import Session +from requests import Session, HTTPError import mod.aai_client as aai_client -from mod import create_app -from mod.pmsh_utils import AppConfig - - -class AaiClientTestCase(TestCase): - - @patch('mod.pmsh_utils.AppConfig._get_pmsh_config') - @patch('mod.update_logging_config') - @patch('mod.get_db_connection_url') - def setUp(self, mock_get_db_url, mock_update_config, mock_get_pmsh_config): - mock_get_db_url.return_value = 'sqlite://' - self.env = EnvironmentVarGuard() - self.env.set('AAI_SERVICE_PORT', '8443') - self.env.set('LOGGER_CONFIG', os.path.join(os.path.dirname(__file__), 'log_config.yaml')) - with open(os.path.join(os.path.dirname(__file__), 'data/cbs_data_1.json'), 'r') as data: - self.cbs_data = json.load(data) - mock_get_pmsh_config.return_value = self.cbs_data - self.app_conf = AppConfig() +from tests.base_setup import BaseClassSetup + + +class AaiClientTestCase(BaseClassSetup): + + @classmethod + def setUpClass(cls): + super().setUpClass() + + def setUp(self): + super().setUp() with open(os.path.join(os.path.dirname(__file__), 'data/aai_xnfs.json'), 'r') as data: self.aai_response_data = data.read() - self.app = create_app() + with open(os.path.join(os.path.dirname(__file__), 'data/aai_model_info.json'), 'r') as data: + self.good_model_info = data.read() + + def tearDown(self): + super().tearDown() + @classmethod + def tearDownClass(cls): + super().tearDownClass() + + @patch('mod.network_function.NetworkFunction.set_sdnc_params') + @patch.object(Session, 'get') @patch.object(Session, 'put') - def test_aai_client_get_pm_sub_data_success(self, mock_session): - mock_session.return_value.status_code = 200 - mock_session.return_value.text = self.aai_response_data + def test_aai_client_get_pm_sub_data_success(self, mock_put_session, mock_get_session, + mock_get_sdnc_params): + mock_put_session.return_value.status_code = 200 + mock_put_session.return_value.text = self.aai_response_data + mock_get_session.return_value.status_code = 200 + mock_get_session.return_value.text = self.good_model_info + mock_get_sdnc_params.return_value = True xnfs = aai_client.get_pmsh_nfs_from_aai(self.app_conf) self.assertEqual(self.app_conf.subscription.subscriptionName, 'ExtraPM-All-gNB-R2B') self.assertEqual(self.app_conf.subscription.administrativeState, 'UNLOCKED') @@ -61,26 +67,48 @@ class AaiClientTestCase(TestCase): mock_session.return_value.status_code = 404 with mock.patch('mod.aai_client._get_all_aai_nf_data', return_value=None): with self.assertRaises(RuntimeError): - aai_client.get_pmsh_nfs_from_aai(self.cbs_data) + aai_client.get_pmsh_nfs_from_aai(self.app_conf) @responses.activate def test_aai_client_get_all_aai_xnf_data_not_found(self): responses.add(responses.PUT, - 'https://1.2.3.4:8443/aai/v19/query?format=simple&nodesOnly=true', + 'https://1.2.3.4:8443/aai/v20/query?format=simple&nodesOnly=true', json={'error': 'not found'}, status=404) self.assertIsNone(aai_client._get_all_aai_nf_data(self.app_conf)) @responses.activate def test_aai_client_get_all_aai_xnf_data_success(self): responses.add(responses.PUT, - 'https://aai:8443/aai/v19/query?format=simple&nodesOnly=true', + 'https://aai:8443/aai/v20/query?format=simple&nodesOnly=true', json={'dummy_data': 'blah_blah'}, status=200) self.assertIsNotNone(aai_client._get_all_aai_nf_data(self.app_conf)) + @responses.activate + def test_aai_client_get_sdnc_params_success(self): + responses.add(responses.GET, + 'https://aai:8443/aai/v20/service-design-and-creation/models/model/' + '6fb9f466-7a79-4109-a2a3-72b340aca53d/model-vers/model-ver/' + '6d25b637-8bca-47e2-af1a-61258424183d', + json=json.loads(self.good_model_info), status=200) + self.assertIsNotNone(aai_client.get_aai_model_data(self.app_conf, + '6fb9f466-7a79-4109-a2a3-72b340aca53d', + '6d25b637-8bca-47e2-af1a-61258424183d', + 'pnf_1')) + + @responses.activate + def test_aai_client_get_sdnc_params_fail(self): + responses.add(responses.GET, + 'https://aai:8443/aai/v20/service-design-and-creation/models/model/' + '9fb9f466-7a79-4109-a2a3-72b340aca53d/model-vers/model-ver/' + 'b7469cc5-be51-41cc-b37f-361537656771', status=404) + with self.assertRaises(HTTPError): + aai_client.get_aai_model_data(self.app_conf, '9fb9f466-7a79-4109-a2a3-72b340aca53d', + 'b7469cc5-be51-41cc-b37f-361537656771', 'pnf_2') + def test_aai_client_get_aai_service_url_fail(self): - self.env.clear() + os.environ.clear() with self.assertRaises(KeyError): aai_client._get_aai_service_url() def test_aai_client_get_aai_service_url_success(self): - self.assertEqual('https://aai:8443', aai_client._get_aai_service_url()) + self.assertEqual('https://aai:8443/aai/v20', aai_client._get_aai_service_url()) -- cgit 1.2.3-korg