DB and test cases update for assign roles to group

This patch modifies CMS DB sql script and adds unit test cases
for role assignment to group.

Change-Id: I9cb4b544c28ef2b6fc8ca22ca91a0e8c93a09565
This commit is contained in:
Chi Lo 2019-05-23 04:14:35 -07:00
parent 1074218ce0
commit 3c59adebd2
4 changed files with 174 additions and 3 deletions

View File

@ -159,7 +159,7 @@ create table if not exists groups_customer_role
primary key (group_id, customer_id, region_id, role_id),
foreign key (`group_id`) references `groups` (`uuid`) ON DELETE CASCADE ON UPDATE NO ACTION,
foreign key (`customer_id`) references `customer` (`id`) ON DELETE CASCADE ON UPDATE NO ACTION,
foreign key (`role_id`) references `groups_role` (`role_id`) ON DELETE CASCADE ON UPDATE NO ACTION,
foreign key (`group_id`, `role_id`) references `groups_role` (`group_id`, `role_id`) ON DELETE CASCADE ON UPDATE NO ACTION,
foreign key (`region_id`) references `cms_region` (`id`) ON DELETE CASCADE ON UPDATE NO ACTION,
index customer_id_idx (customer_id),
index role_id_idx (role_id));
@ -173,6 +173,6 @@ create table if not exists groups_domain_role
primary key (group_id, domain_name, region_id, role_id),
foreign key (`group_id`) references `groups` (`uuid`) ON DELETE CASCADE ON UPDATE NO ACTION,
foreign key (`domain_name`) references `cms_domain` (`name`) ON DELETE CASCADE ON UPDATE NO ACTION,
foreign key (`role_id`) references `groups_role` (`role_id`) ON DELETE CASCADE ON UPDATE NO ACTION,
foreign key (`group_id`, `role_id`) references `groups_role` (`group_id`, `role_id`) ON DELETE CASCADE ON UPDATE NO ACTION,
foreign key (`region_id`) references `cms_region` (`id`) ON DELETE CASCADE ON UPDATE NO ACTION,
index role_id_idx (role_id));

View File

@ -209,6 +209,22 @@ class TestGroupLogic(FunctionalTest):
assert record_mock.read_group_by_uuid.called
assert record_mock.get_regions_for_group.called
def test_assign_roles_to_group_region_on_customer_success(self):
roles_assginments = [models.RoleAssignment(
roles=['a_role'], customer='customer')]
logic = group_logic.GroupLogic()
logic.assign_roles(
'group_uuid', roles_assginments, 'some_trans_id', region='local')
assert data_manager_mock.add_groups_role_on_customer.called
assert data_manager_mock.get_customer_id_by_uuid.called
assert data_manager_mock.commit.called
assert data_manager_mock.get_role_id_by_name.called
assert not data_manager_mock.rollback.called
assert record_mock.read_group_by_uuid.called
assert record_mock.get_region_by_keys.called
def test_assign_roles_to_group_on_domain_error(self):
global mock_returns_error
mock_returns_error = True
@ -220,6 +236,7 @@ class TestGroupLogic(FunctionalTest):
self.assertRaises(SystemError, logic.assign_roles, 'group_uuid',
roles_assginments, 'some_trans_id')
assert data_manager_mock.add_groups_role_on_domain.called
assert data_manager_mock.rollback.called
def test_assign_roles_to_group_on_customer_error(self):
@ -233,6 +250,41 @@ class TestGroupLogic(FunctionalTest):
self.assertRaises(SystemError, logic.assign_roles, 'group_uuid',
roles_assginments, 'some_trans_id')
assert data_manager_mock.add_groups_role_on_customer.called
assert data_manager_mock.rollback.called
def test_assign_roles_to_group_region_error(self):
global mock_returns_error
global flow_type
mock_returns_error = True
flow_type = 1
roles_assginments = [models.RoleAssignment(
roles=['a_role'], customer='customer')]
logic = group_logic.GroupLogic()
self.assertRaises(SystemError, logic.assign_roles, 'group_uuid',
roles_assginments, 'some_trans_id')
assert record_mock.get_regions_for_group.called
assert not data_manager_mock.add_groups_role_on_customer.called
assert data_manager_mock.rollback.called
def test_assign_roles_to_group_region_region_error(self):
global mock_returns_error
global flow_type
mock_returns_error = True
flow_type = 1
roles_assginments = [models.RoleAssignment(
roles=['a_role'], customer='customer')]
logic = group_logic.GroupLogic()
self.assertRaises(SystemError, logic.assign_roles, 'group_uuid',
roles_assginments, 'some_trans_id', region='local')
assert record_mock.get_region_by_keys.called
assert not data_manager_mock.add_groups_role_on_customer.called
assert data_manager_mock.rollback.called
def test_unassign_roles_from_group_on_domain_success(self):
@ -388,6 +440,8 @@ def get_mock_datamanager():
record_mock.read_group_by_uuid.return_value = sql_group
record_mock.get_regions_for_group.return_value = [
sql_models.GroupsRegion(region_id=1, group_id="group_id")]
record_mock.get_region_by_keys.return_value = \
sql_models.GroupsRegion(region_id=1, group_id="group_id")
record_mock.remove_customer_role_from_group.return_value = result_mock
record_mock.remove_domain_role_from_group.return_value = result_mock
record_mock.check_groups_customer_role_exist.return_value = False
@ -418,5 +472,9 @@ def get_mock_datamanager():
record_mock.remove_domain_role_from_group.side_effect = SystemError()
record_mock.remove_customer_role_from_group.side_effect = SystemError()
if flow_type == 1:
record_mock.get_regions_for_group.side_effect = SystemError()
record_mock.get_region_by_keys.side_effect = SystemError()
data_manager_mock.get_record.return_value = record_mock
return data_manager_mock

View File

@ -0,0 +1,110 @@
import mock
import requests
from orm.services.customer_manager.cms_rest.controllers.v1.orm.group\
import region_roles
from orm.services.customer_manager.cms_rest.logic.error_base import ErrorStatus
from orm.services.customer_manager.cms_rest.model import GroupModels
from orm.tests.unit.cms import FunctionalTest
from wsme.exc import ClientSideError
group_logic_mock = None
class TestGroupsRegionRoleController(FunctionalTest):
def setUp(self):
FunctionalTest.setUp(self)
region_roles.authentication = mock.MagicMock()
region_roles.GroupLogic = get_mock_group_logic
region_roles.GroupLogic.return_error = 0
region_roles.utils = mock.MagicMock()
region_roles.utils.audit_trail.return_value = None
region_roles.err_utils = mock.MagicMock()
def tearDown(self):
FunctionalTest.tearDown(self)
def test_assign_roles_to_group_region(self):
# given
requests.post = mock.MagicMock(return_value=ResponseMock(200))
# when
response = self.app.post_json(
'/v1/orm/groups/{groups id}/regions/{region id}/roles/',
GROUPS_ROLE_JSON)
# assert
assert response.status_int == 200
assert region_roles.utils.audit_trail.called
assert group_logic_mock.assign_roles_called
def test_assign_roles_to_group_region_fail(self):
# given
requests.post = mock.MagicMock()
region_roles.GroupLogic.return_error = 1
region_roles.err_utils.get_error = mock.MagicMock(
return_value=ClientSideError("blabla", 500))
# when
response = self.app.post_json(
'/v1/orm/groups/{groups id}/regions/{region id}/roles/',
GROUPS_ROLE_JSON, expect_errors=True)
# assert
self.assertEqual(response.status_int, 500)
def test_assign_roles_to_group_region_bad_request(self):
# given
requests.post = mock.MagicMock()
region_roles.GroupLogic.return_error = 2
region_roles.err_utils.get_error = mock.MagicMock(
return_value=ClientSideError("blabla", 404))
# when
response = self.app.post_json(
'/v1/orm/groups/{groups_id}/regions/{region id}/roles/',
GROUPS_ROLE_JSON, expect_errors=True)
# assert
self.assertEqual(response.status_int, 404)
def get_mock_group_logic():
global group_logic_mock
group_logic_mock = mock.MagicMock()
if region_roles.GroupLogic.return_error == 0:
res = GroupModels.RoleResultWrapper(transaction_id='1',
roles=[],
links={},
created='1')
group_logic_mock.assign_roles.return_value = res
elif region_roles.GroupLogic.return_error == 1:
group_logic_mock.assign_roles.side_effect = SystemError()
elif region_roles.GroupLogic.return_error == 2:
group_logic_mock.assign_roles.side_effect = ErrorStatus(
status_code=404)
return group_logic_mock
class ResponseMock:
def __init__(self, status_code=200):
self.status_code = status_code
GROUPS_ROLE_JSON = [
{
"customer": "customer-id",
"roles": [
"role1",
"role2"
]
}
]

View File

@ -119,7 +119,10 @@ class CmsTests(TestCase):
args.userdomain,)),
'assign_group_roles': (
requests.post, 'groups/%s/roles' % args.groupid,)
requests.post, 'groups/%s/roles' % args.groupid,),
'assign_group_region_roles': (
requests.post, 'groups/%s/regions/%s/roles' % (args.groupid,
args.regionid))
}
# Assert that each subcommand returns the expected details