summaryrefslogtreecommitdiffstats
path: root/components/pm-subscription-handler/tests/test_aai_service.py
diff options
context:
space:
mode:
Diffstat (limited to 'components/pm-subscription-handler/tests/test_aai_service.py')
-rw-r--r--components/pm-subscription-handler/tests/test_aai_service.py88
1 files changed, 58 insertions, 30 deletions
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())