summaryrefslogtreecommitdiffstats
path: root/components/pm-subscription-handler/tests
diff options
context:
space:
mode:
authorraviteja.karumuri <raviteja.karumuri@est.tech>2022-01-12 18:48:44 +0000
committerraviteja.karumuri <raviteja.karumuri@est.tech>2022-01-14 12:33:33 +0000
commit5b11f4ff05cf4bd3f042a4c531848b939e4ead8a (patch)
tree229ce963fc71fb01f5818076bdb4eeacc24e4e7c /components/pm-subscription-handler/tests
parent54b8d2537deba7fdc8c9e63fc73e97ecdc63368a (diff)
[PMSH] Delete subscription API by Name
Issue-ID: DCAEGEN2-2821 Signed-off-by: Raviteja, Karumuri <raviteja.karumuri@est.tech> Change-Id: I22eb00c74e40b5428c3c7bd2b0546175cd6f30ed
Diffstat (limited to 'components/pm-subscription-handler/tests')
-rwxr-xr-xcomponents/pm-subscription-handler/tests/test_controller.py54
1 files changed, 52 insertions, 2 deletions
diff --git a/components/pm-subscription-handler/tests/test_controller.py b/components/pm-subscription-handler/tests/test_controller.py
index fa96c319..1de7c175 100755
--- a/components/pm-subscription-handler/tests/test_controller.py
+++ b/components/pm-subscription-handler/tests/test_controller.py
@@ -22,14 +22,14 @@ from http import HTTPStatus
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
+ get_subscriptions, get_meas_group_with_nfs, delete_subscription_by_name
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 create_subscription_data, create_multiple_subscription_data, \
create_multiple_network_function_data
-from mod.api.services import measurement_group_service, nf_service
+from mod.api.services import measurement_group_service, nf_service, subscription_service
class ControllerTestCase(BaseClassSetup):
@@ -202,3 +202,53 @@ class ControllerTestCase(BaseClassSetup):
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)
+
+ def test_delete_when_state_unlocked(self):
+ subscription_unlocked_data = create_subscription_data('MG_unlocked')
+ subscription_unlocked_data.measurement_groups[0].measurement_group_name = 'unlock'
+ subscription_unlocked_data.measurement_groups[0].administrative_state = 'UNLOCKED'
+ db.session.add(subscription_unlocked_data)
+ db.session.add(subscription_unlocked_data.measurement_groups[0])
+ db.session.commit()
+ db.session.remove()
+ message, status_code = delete_subscription_by_name('MG_unlocked')
+ self.assertEqual(status_code, HTTPStatus.CONFLICT.value)
+ self.assertEqual(subscription_service.query_subscription_by_name('MG_unlocked')
+ .subscription_name, 'MG_unlocked')
+
+ def test_delete_when_state_locked(self):
+ subscription_unlocked_data = create_subscription_data('MG_locked')
+ subscription_unlocked_data.measurement_groups[0].measurement_group_name = 'lock'
+ subscription_unlocked_data.measurement_groups[0].administrative_state = 'LOCKED'
+ db.session.add(subscription_unlocked_data)
+ db.session.add(subscription_unlocked_data.measurement_groups[0])
+ db.session.commit()
+ db.session.remove()
+ none_type, status_code = delete_subscription_by_name('MG_locked')
+ self.assertEqual(none_type, None)
+ self.assertEqual(status_code, HTTPStatus.NO_CONTENT.value)
+ self.assertEqual(subscription_service.query_subscription_by_name('MG_locked'), None)
+
+ def test_delete_when_state_locking(self):
+ subscription_locking_data = create_subscription_data('MG_locking')
+ subscription_locking_data.measurement_groups[0].measurement_group_name = 'locking'
+ subscription_locking_data.measurement_groups[0].administrative_state = 'LOCKING'
+ db.session.add(subscription_locking_data)
+ db.session.add(subscription_locking_data.measurement_groups[0])
+ db.session.commit()
+ db.session.remove()
+ message, status_code = delete_subscription_by_name('MG_locking')
+ self.assertEqual(status_code, HTTPStatus.CONFLICT.value)
+ self.assertEqual(subscription_service.query_subscription_by_name('MG_locking')
+ .subscription_name, 'MG_locking')
+
+ def test_delete_sub_none(self):
+ message, status_code = delete_subscription_by_name('None')
+ self.assertEqual(message['error'], 'Subscription is not defined with name None')
+ self.assertEqual(status_code, HTTPStatus.NOT_FOUND.value)
+
+ @patch('mod.api.services.subscription_service.query_to_delete_subscription_by_name',
+ MagicMock(side_effect=Exception('something failed')))
+ def test_delete_sub_exception(self):
+ error, status_code = delete_subscription_by_name('None')
+ self.assertEqual(status_code, HTTPStatus.INTERNAL_SERVER_ERROR.value)