summaryrefslogtreecommitdiffstats
path: root/components/pm-subscription-handler/tests/test_controller.py
diff options
context:
space:
mode:
Diffstat (limited to 'components/pm-subscription-handler/tests/test_controller.py')
-rwxr-xr-xcomponents/pm-subscription-handler/tests/test_controller.py83
1 files changed, 72 insertions, 11 deletions
diff --git a/components/pm-subscription-handler/tests/test_controller.py b/components/pm-subscription-handler/tests/test_controller.py
index 7bd72a29..962e8fb2 100755
--- a/components/pm-subscription-handler/tests/test_controller.py
+++ b/components/pm-subscription-handler/tests/test_controller.py
@@ -20,13 +20,16 @@ import os
from unittest.mock import patch, MagicMock
from http import HTTPStatus
-from mod import aai_client
-from mod.api.controller import status, post_subscription, get_subscription_by_name
+from mod import aai_client, db
+from mod.api.controller import status, post_subscription, get_subscription_by_name, \
+ get_subscriptions, get_meas_group_with_nfs
from tests.base_setup import BaseClassSetup
from mod.api.db_models import SubscriptionModel, NfMeasureGroupRelationalModel
from mod.subscription import SubNfState
from mod.network_function import NetworkFunctionFilter
-from tests.base_setup import subscription_data
+from tests.base_setup import create_subscription_data, create_multiple_subscription_data, \
+ create_multiple_network_function_data
+from mod.api.services import measurement_group_service, nf_service
class ControllerTestCase(BaseClassSetup):
@@ -111,11 +114,11 @@ class ControllerTestCase(BaseClassSetup):
self.assertEqual(response[1], 400)
self.assertEqual(response[0], 'No value provided in subscription name')
- @patch('mod.api.services.subscription_service.get_subscription_by_name',
- MagicMock(return_value=subscription_data('sub_demo')))
+ @patch('mod.api.services.subscription_service.query_subscription_by_name',
+ MagicMock(return_value=create_subscription_data('sub_demo')))
def test_get_subscription_by_name_api(self):
sub, status_code = get_subscription_by_name('sub_demo')
- self.assertEqual(status_code, HTTPStatus.OK)
+ self.assertEqual(status_code, HTTPStatus.OK.value)
self.assertEqual(sub['subscription']['subscriptionName'], 'sub_demo')
self.assertEqual(sub['subscription']['nfFilter']['nfNames'],
['^pnf.*', '^vnf.*'])
@@ -125,16 +128,74 @@ class ControllerTestCase(BaseClassSetup):
self.assertEqual(sub['subscription']['operationalPolicyName'],
'pmsh_operational_policy')
- @patch('mod.api.services.subscription_service.get_subscription_by_name',
+ @patch('mod.api.services.subscription_service.query_subscription_by_name',
MagicMock(return_value=None))
- def test_get_subscription_by_name_api_error(self):
+ def test_get_subscription_by_name_api_none(self):
sub, status_code = get_subscription_by_name('sub_demo')
- self.assertEqual(status_code, HTTPStatus.NOT_FOUND)
+ self.assertEqual(status_code, HTTPStatus.NOT_FOUND.value)
self.assertEqual(sub['error'],
'Subscription was not defined with the name : sub_demo')
- @patch('mod.api.services.subscription_service.get_subscription_by_name',
+ @patch('mod.api.services.subscription_service.query_subscription_by_name',
MagicMock(side_effect=Exception('something failed')))
def test_get_subscription_by_name_api_exception(self):
sub, status_code = get_subscription_by_name('sub_demo')
- self.assertEqual(status_code, HTTPStatus.INTERNAL_SERVER_ERROR)
+ self.assertEqual(status_code, HTTPStatus.INTERNAL_SERVER_ERROR.value)
+
+ @patch('mod.api.services.subscription_service.query_all_subscriptions',
+ MagicMock(return_value=create_multiple_subscription_data(
+ ['sub_demo_one', 'sub_demo_two'])))
+ def test_get_subscriptions_api(self):
+ subs, status_code = get_subscriptions()
+ self.assertEqual(status_code, HTTPStatus.OK.value)
+ self.assertEqual(subs[0]['subscription']['subscriptionName'], 'sub_demo_one')
+ self.assertEqual(subs[1]['subscription']['subscriptionName'], 'sub_demo_two')
+ self.assertEqual(subs[1]['subscription']['measurementGroups'][0]['measurementGroup']
+ ['measurementGroupName'], 'MG1')
+ self.assertEqual(len(subs[1]['subscription']['measurementGroups']), 2)
+ self.assertEqual(len(subs), 2)
+
+ @patch('mod.api.services.subscription_service.query_all_subscriptions',
+ MagicMock(return_value=None))
+ def test_get_subscriptions_api_none(self):
+ subs, status_code = get_subscriptions()
+ self.assertEqual(status_code, HTTPStatus.OK.value)
+ self.assertEqual(subs, [])
+
+ @patch('mod.api.services.subscription_service.query_all_subscriptions',
+ MagicMock(side_effect=Exception('something failed')))
+ def test_get_subscriptions_api_exception(self):
+ subs, status_code = get_subscriptions()
+ self.assertEqual(status_code, HTTPStatus.INTERNAL_SERVER_ERROR.value)
+
+ def test_get_meas_group_with_nfs_api(self):
+ sub = create_subscription_data('sub1')
+ nf_list = create_multiple_network_function_data(['pnf101', 'pnf102'])
+ measurement_group_service.save_measurement_group(sub.measurement_groups[0].
+ serialize()['measurementGroup'],
+ sub.subscription_name)
+ for nf in nf_list:
+ nf_service.save_nf(nf)
+ measurement_group_service. \
+ apply_nf_status_to_measurement_group(nf.nf_name, sub.measurement_groups[0].
+ measurement_group_name,
+ SubNfState.PENDING_CREATE.value)
+ db.session.commit()
+ mg_with_nfs, status_code = get_meas_group_with_nfs('sub1', 'MG1')
+ self.assertEqual(status_code, HTTPStatus.OK.value)
+ self.assertEqual(mg_with_nfs['subscriptionName'], 'sub1')
+ self.assertEqual(mg_with_nfs['measurementGroupName'], 'MG1')
+ self.assertEqual(mg_with_nfs['administrativeState'], 'UNLOCKED')
+ self.assertEqual(len(mg_with_nfs['networkFunctions']), 2)
+
+ def test_get_meas_group_with_nfs_api_none(self):
+ error, status_code = get_meas_group_with_nfs('sub1', 'MG1')
+ self.assertEqual(error['error'], 'measurement group was not defined with '
+ 'the sub name: sub1 and meas group name: MG1')
+ self.assertEqual(status_code, HTTPStatus.NOT_FOUND.value)
+
+ @patch('mod.api.services.measurement_group_service.query_meas_group_by_name',
+ MagicMock(side_effect=Exception('something failed')))
+ def test_get_meas_group_with_nfs_api_exception(self):
+ error, status_code = get_meas_group_with_nfs('sub1', 'MG1')
+ self.assertEqual(status_code, HTTPStatus.INTERNAL_SERVER_ERROR.value)