Convert identity.groups tests into mock
In addition, domain_get() call checks previously succeeded somehow with mox test, but they now fails after mock migration. api.keystone.get_effective_domain_id() is now mocked instead of api.keystone.domain_get(). There is no need to test the internal of api.keystone, so get_effective_domain_id() is the right place to mock. blueprint mock-framework-in-unit-tests Change-Id: I567168a8001875efb3e768aa732ceb562b1dd99f
This commit is contained in:
parent
db350910e4
commit
0a149af36b
@ -12,11 +12,9 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from django import http
|
|
||||||
from django.urls import reverse
|
from django.urls import reverse
|
||||||
|
|
||||||
from mox3.mox import IgnoreArg
|
import mock
|
||||||
from mox3.mox import IsA
|
|
||||||
|
|
||||||
from openstack_dashboard import api
|
from openstack_dashboard import api
|
||||||
from openstack_dashboard.test import helpers as test
|
from openstack_dashboard.test import helpers as test
|
||||||
@ -33,8 +31,6 @@ GROUP_ADD_MEMBER_URL = reverse(constants.GROUPS_ADD_MEMBER_URL, args=[1])
|
|||||||
|
|
||||||
class GroupsViewTests(test.BaseAdminViewTests):
|
class GroupsViewTests(test.BaseAdminViewTests):
|
||||||
|
|
||||||
use_mox = True
|
|
||||||
|
|
||||||
def _get_domain_id(self):
|
def _get_domain_id(self):
|
||||||
return self.request.session.get('domain_context', None)
|
return self.request.session.get('domain_context', None)
|
||||||
|
|
||||||
@ -46,18 +42,15 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
if group.domain_id == domain_id]
|
if group.domain_id == domain_id]
|
||||||
return groups
|
return groups
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('domain_get',
|
@test.create_mocks({api.keystone: ('get_effective_domain_id',
|
||||||
'group_list',)})
|
'group_list',)})
|
||||||
def test_index(self):
|
def test_index(self):
|
||||||
domain_id = self._get_domain_id()
|
domain_id = self._get_domain_id()
|
||||||
groups = self._get_groups(domain_id)
|
groups = self._get_groups(domain_id)
|
||||||
filters = {}
|
filters = {}
|
||||||
api.keystone.group_list(IgnoreArg(),
|
|
||||||
domain=domain_id,
|
|
||||||
filters=filters) \
|
|
||||||
.AndReturn(groups)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
self.mock_get_effective_domain_id.return_value = None
|
||||||
|
self.mock_group_list.return_value = groups
|
||||||
|
|
||||||
res = self.client.get(GROUPS_INDEX_URL)
|
res = self.client.get(GROUPS_INDEX_URL)
|
||||||
|
|
||||||
@ -71,8 +64,13 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
self.assertContains(res, 'Edit')
|
self.assertContains(res, 'Edit')
|
||||||
self.assertContains(res, 'Delete Group')
|
self.assertContains(res, 'Delete Group')
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('group_list',
|
self.mock_get_effective_domain_id.assert_called_once_with(
|
||||||
'get_effective_domain_id')})
|
test.IsHttpRequest())
|
||||||
|
self.mock_group_list.assert_called_once_with(test.IsHttpRequest(),
|
||||||
|
domain=domain_id,
|
||||||
|
filters=filters)
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('group_list',)})
|
||||||
def test_index_with_domain(self):
|
def test_index_with_domain(self):
|
||||||
domain = self.domains.get(id="1")
|
domain = self.domains.get(id="1")
|
||||||
filters = {}
|
filters = {}
|
||||||
@ -80,11 +78,7 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
domain_context_name=domain.name)
|
domain_context_name=domain.name)
|
||||||
groups = self._get_groups(domain.id)
|
groups = self._get_groups(domain.id)
|
||||||
|
|
||||||
api.keystone.group_list(IsA(http.HttpRequest),
|
self.mock_group_list.return_value = groups
|
||||||
domain=domain.id,
|
|
||||||
filters=filters).AndReturn(groups)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
res = self.client.get(GROUPS_INDEX_URL)
|
res = self.client.get(GROUPS_INDEX_URL)
|
||||||
|
|
||||||
@ -98,21 +92,20 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
self.assertContains(res, 'Edit')
|
self.assertContains(res, 'Edit')
|
||||||
self.assertContains(res, 'Delete Group')
|
self.assertContains(res, 'Delete Group')
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('domain_get',
|
self.mock_group_list.assert_called_once_with(test.IsHttpRequest(),
|
||||||
|
domain=domain.id,
|
||||||
|
filters=filters)
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('get_effective_domain_id',
|
||||||
'group_list',
|
'group_list',
|
||||||
'keystone_can_edit_group')})
|
'keystone_can_edit_group')})
|
||||||
def test_index_with_keystone_can_edit_group_false(self):
|
def test_index_with_keystone_can_edit_group_false(self):
|
||||||
domain_id = self._get_domain_id()
|
domain_id = self._get_domain_id()
|
||||||
groups = self._get_groups(domain_id)
|
groups = self._get_groups(domain_id)
|
||||||
filters = {}
|
filters = {}
|
||||||
api.keystone.group_list(IgnoreArg(),
|
self.mock_get_effective_domain_id.return_value = domain_id
|
||||||
domain=domain_id,
|
self.mock_group_list.return_value = groups
|
||||||
filters=filters) \
|
self.mock_keystone_can_edit_group.return_value = False
|
||||||
.AndReturn(groups)
|
|
||||||
api.keystone.keystone_can_edit_group() \
|
|
||||||
.MultipleTimes().AndReturn(False)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
res = self.client.get(GROUPS_INDEX_URL)
|
res = self.client.get(GROUPS_INDEX_URL)
|
||||||
|
|
||||||
@ -123,21 +116,23 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
self.assertNotContains(res, 'Edit')
|
self.assertNotContains(res, 'Edit')
|
||||||
self.assertNotContains(res, 'Delete Group')
|
self.assertNotContains(res, 'Delete Group')
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('group_create',
|
self.mock_get_effective_domain_id.assert_called_once_with(
|
||||||
'domain_get')})
|
test.IsHttpRequest())
|
||||||
|
self.mock_group_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(),
|
||||||
|
domain=domain_id,
|
||||||
|
filters=filters)
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_keystone_can_edit_group, 19, mock.call())
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('group_create',
|
||||||
|
'get_effective_domain_id')})
|
||||||
def test_create(self):
|
def test_create(self):
|
||||||
domain_id = self._get_domain_id()
|
domain_id = self._get_domain_id()
|
||||||
domain = self.domains.get(id="1")
|
|
||||||
group = self.groups.get(id="1")
|
group = self.groups.get(id="1")
|
||||||
|
|
||||||
api.keystone.domain_get(IsA(http.HttpRequest), '1') \
|
self.mock_get_effective_domain_id.return_value = None
|
||||||
.AndReturn(domain)
|
self.mock_group_create.return_value = group
|
||||||
api.keystone.group_create(IsA(http.HttpRequest),
|
|
||||||
description=group.description,
|
|
||||||
domain_id=domain_id,
|
|
||||||
name=group.name).AndReturn(group)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
formData = {'method': 'CreateGroupForm',
|
formData = {'method': 'CreateGroupForm',
|
||||||
'name': group.name,
|
'name': group.name,
|
||||||
@ -147,7 +142,15 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
self.assertNoFormErrors(res)
|
self.assertNoFormErrors(res)
|
||||||
self.assertMessageCount(success=1)
|
self.assertMessageCount(success=1)
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('group_create',)})
|
self.mock_get_effective_domain_id.assert_called_once_with(
|
||||||
|
test.IsHttpRequest())
|
||||||
|
self.mock_group_create.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(),
|
||||||
|
description=group.description,
|
||||||
|
domain_id=domain_id,
|
||||||
|
name=group.name)
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('group_create',)})
|
||||||
def test_create_with_domain(self):
|
def test_create_with_domain(self):
|
||||||
domain = self.domains.get(id="3")
|
domain = self.domains.get(id="3")
|
||||||
group = self.groups.get(id="1")
|
group = self.groups.get(id="1")
|
||||||
@ -155,12 +158,7 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
self.setSessionValues(domain_context=domain.id,
|
self.setSessionValues(domain_context=domain.id,
|
||||||
domain_context_name=domain.name)
|
domain_context_name=domain.name)
|
||||||
|
|
||||||
api.keystone.group_create(IsA(http.HttpRequest),
|
self.mock_group_create.return_value = group
|
||||||
description=group.description,
|
|
||||||
domain_id=domain.id,
|
|
||||||
name=group.name).AndReturn(group)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
formData = {'method': 'CreateGroupForm',
|
formData = {'method': 'CreateGroupForm',
|
||||||
'name': group.name,
|
'name': group.name,
|
||||||
@ -170,19 +168,20 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
self.assertNoFormErrors(res)
|
self.assertNoFormErrors(res)
|
||||||
self.assertMessageCount(success=1)
|
self.assertMessageCount(success=1)
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('group_get',
|
self.mock_group_create.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(),
|
||||||
|
description=group.description,
|
||||||
|
domain_id=domain.id,
|
||||||
|
name=group.name)
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('group_get',
|
||||||
'group_update')})
|
'group_update')})
|
||||||
def test_update(self):
|
def test_update(self):
|
||||||
group = self.groups.get(id="1")
|
group = self.groups.get(id="1")
|
||||||
test_description = 'updated description'
|
test_description = 'updated description'
|
||||||
|
|
||||||
api.keystone.group_get(IsA(http.HttpRequest), '1').AndReturn(group)
|
self.mock_group_get.return_value = group
|
||||||
api.keystone.group_update(IsA(http.HttpRequest),
|
self.mock_group_update.return_value = None
|
||||||
description=test_description,
|
|
||||||
group_id=group.id,
|
|
||||||
name=group.name).AndReturn(None)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
formData = {'method': 'UpdateGroupForm',
|
formData = {'method': 'UpdateGroupForm',
|
||||||
'group_id': group.id,
|
'group_id': group.id,
|
||||||
@ -193,7 +192,14 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
|
|
||||||
self.assertNoFormErrors(res)
|
self.assertNoFormErrors(res)
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('domain_get',
|
self.mock_group_get.assert_called_once_with(test.IsHttpRequest(), '1')
|
||||||
|
self.mock_group_update.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(),
|
||||||
|
description=test_description,
|
||||||
|
group_id=group.id,
|
||||||
|
name=group.name)
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('get_effective_domain_id',
|
||||||
'group_list',
|
'group_list',
|
||||||
'group_delete')})
|
'group_delete')})
|
||||||
def test_delete_group(self):
|
def test_delete_group(self):
|
||||||
@ -201,20 +207,24 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
filters = {}
|
filters = {}
|
||||||
group = self.groups.get(id="2")
|
group = self.groups.get(id="2")
|
||||||
|
|
||||||
api.keystone.group_list(IgnoreArg(),
|
self.mock_get_effective_domain_id.return_value = domain_id
|
||||||
domain=domain_id,
|
self.mock_group_list.return_value = self.groups.list()
|
||||||
filters=filters) \
|
self.mock_group_delete.return_value = None
|
||||||
.AndReturn(self.groups.list())
|
|
||||||
api.keystone.group_delete(IgnoreArg(), group.id)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
formData = {'action': 'groups__delete__%s' % group.id}
|
formData = {'action': 'groups__delete__%s' % group.id}
|
||||||
res = self.client.post(GROUPS_INDEX_URL, formData)
|
res = self.client.post(GROUPS_INDEX_URL, formData)
|
||||||
|
|
||||||
self.assertRedirectsNoFollow(res, GROUPS_INDEX_URL)
|
self.assertRedirectsNoFollow(res, GROUPS_INDEX_URL)
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('get_effective_domain_id',
|
self.mock_get_effective_domain_id.assert_called_once_with(
|
||||||
|
test.IsHttpRequest())
|
||||||
|
self.mock_group_list.assert_called_once_with(test.IsHttpRequest(),
|
||||||
|
domain=domain_id,
|
||||||
|
filters=filters)
|
||||||
|
self.mock_group_delete.assert_called_once_with(test.IsHttpRequest(),
|
||||||
|
group.id)
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('get_effective_domain_id',
|
||||||
'group_get',
|
'group_get',
|
||||||
'user_list',)})
|
'user_list',)})
|
||||||
def test_manage(self):
|
def test_manage(self):
|
||||||
@ -222,27 +232,28 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
group_members = self.users.list()
|
group_members = self.users.list()
|
||||||
domain_id = self._get_domain_id()
|
domain_id = self._get_domain_id()
|
||||||
|
|
||||||
api.keystone.group_get(IsA(http.HttpRequest), group.id).\
|
self.mock_group_get.return_value = group
|
||||||
AndReturn(group)
|
self.mock_get_effective_domain_id.return_value = domain_id
|
||||||
|
self.mock_user_list.return_value = group_members
|
||||||
if api.keystone.VERSIONS.active >= 3:
|
|
||||||
api.keystone.get_effective_domain_id(
|
|
||||||
IgnoreArg()).AndReturn(domain_id)
|
|
||||||
api.keystone.user_list(
|
|
||||||
IgnoreArg(), group=group.id, domain=domain_id).AndReturn(
|
|
||||||
group_members)
|
|
||||||
|
|
||||||
else:
|
|
||||||
api.keystone.user_list(
|
|
||||||
IgnoreArg(), group=group.id).AndReturn(group_members)
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
res = self.client.get(GROUP_MANAGE_URL)
|
res = self.client.get(GROUP_MANAGE_URL)
|
||||||
|
|
||||||
self.assertTemplateUsed(res, constants.GROUPS_MANAGE_VIEW_TEMPLATE)
|
self.assertTemplateUsed(res, constants.GROUPS_MANAGE_VIEW_TEMPLATE)
|
||||||
self.assertItemsEqual(res.context['table'].data, group_members)
|
self.assertItemsEqual(res.context['table'].data, group_members)
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('get_effective_domain_id',
|
self.mock_group_get.assert_called_once_with(test.IsHttpRequest(),
|
||||||
|
group.id)
|
||||||
|
if api.keystone.VERSIONS.active >= 3:
|
||||||
|
self.mock_get_effective_domain_id.assert_called_once_with(
|
||||||
|
test.IsHttpRequest())
|
||||||
|
self.mock_user_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), group=group.id, domain=domain_id)
|
||||||
|
else:
|
||||||
|
self.mock_get_effective_domain_id.assert_not_called()
|
||||||
|
self.mock_user_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), group=group.id)
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('get_effective_domain_id',
|
||||||
'user_list',
|
'user_list',
|
||||||
'remove_group_user')})
|
'remove_group_user')})
|
||||||
def test_remove_user(self):
|
def test_remove_user(self):
|
||||||
@ -250,21 +261,9 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
user = self.users.get(id="2")
|
user = self.users.get(id="2")
|
||||||
domain_id = self._get_domain_id()
|
domain_id = self._get_domain_id()
|
||||||
|
|
||||||
if api.keystone.VERSIONS.active >= 3:
|
self.mock_get_effective_domain_id.return_value = domain_id
|
||||||
api.keystone.get_effective_domain_id(
|
self.mock_user_list.return_value = self.users.list()
|
||||||
IgnoreArg()).AndReturn(domain_id)
|
self.mock_remove_group_user.return_value = None
|
||||||
|
|
||||||
api.keystone.user_list(
|
|
||||||
IgnoreArg(), group=group.id, domain=domain_id).AndReturn(
|
|
||||||
self.users.list())
|
|
||||||
else:
|
|
||||||
api.keystone.user_list(
|
|
||||||
IgnoreArg(), group=group.id).AndReturn(self.users.list())
|
|
||||||
|
|
||||||
api.keystone.remove_group_user(IgnoreArg(),
|
|
||||||
group_id=group.id,
|
|
||||||
user_id=user.id)
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
formData = {'action': 'group_members__removeGroupMember__%s' % user.id}
|
formData = {'action': 'group_members__removeGroupMember__%s' % user.id}
|
||||||
res = self.client.post(GROUP_MANAGE_URL, formData)
|
res = self.client.post(GROUP_MANAGE_URL, formData)
|
||||||
@ -272,7 +271,22 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
self.assertRedirectsNoFollow(res, GROUP_MANAGE_URL)
|
self.assertRedirectsNoFollow(res, GROUP_MANAGE_URL)
|
||||||
self.assertMessageCount(success=1)
|
self.assertMessageCount(success=1)
|
||||||
|
|
||||||
@test.create_stubs({api.keystone: ('get_effective_domain_id',
|
if api.keystone.VERSIONS.active >= 3:
|
||||||
|
self.mock_get_effective_domain_id.assert_called_once_with(
|
||||||
|
test.IsHttpRequest())
|
||||||
|
self.mock_user_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), group=group.id, domain=domain_id)
|
||||||
|
else:
|
||||||
|
self.mock_get_effective_domain_id.assert_not_called()
|
||||||
|
self.mock_user_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), group=group.id)
|
||||||
|
|
||||||
|
self.mock_remove_group_user.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(),
|
||||||
|
group_id=group.id,
|
||||||
|
user_id=user.id)
|
||||||
|
|
||||||
|
@test.create_mocks({api.keystone: ('get_effective_domain_id',
|
||||||
'group_get',
|
'group_get',
|
||||||
'user_list',
|
'user_list',
|
||||||
'add_group_user')})
|
'add_group_user')})
|
||||||
@ -281,22 +295,13 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
user = self.users.get(id="2")
|
user = self.users.get(id="2")
|
||||||
domain_id = group.domain_id
|
domain_id = group.domain_id
|
||||||
|
|
||||||
api.keystone.get_effective_domain_id(IgnoreArg()).AndReturn(domain_id)
|
self.mock_get_effective_domain_id.return_value = domain_id
|
||||||
|
self.mock_group_get.return_value = group
|
||||||
api.keystone.group_get(IsA(http.HttpRequest), group.id).\
|
self.mock_user_list.side_effect = [
|
||||||
AndReturn(group)
|
self.users.list(),
|
||||||
|
self.users.list()[2:],
|
||||||
api.keystone.user_list(IgnoreArg(), domain=domain_id).\
|
]
|
||||||
AndReturn(self.users.list())
|
self.mock_add_group_user.return_value = None
|
||||||
|
|
||||||
api.keystone.user_list(IgnoreArg(), domain=domain_id, group=group.id).\
|
|
||||||
AndReturn(self.users.list()[2:])
|
|
||||||
|
|
||||||
api.keystone.add_group_user(IgnoreArg(),
|
|
||||||
group_id=group.id,
|
|
||||||
user_id=user.id)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
formData = {'action': 'group_non_members__add__%s' % user.id}
|
formData = {'action': 'group_non_members__add__%s' % user.id}
|
||||||
res = self.client.post(GROUP_ADD_MEMBER_URL, formData)
|
res = self.client.post(GROUP_ADD_MEMBER_URL, formData)
|
||||||
@ -304,6 +309,18 @@ class GroupsViewTests(test.BaseAdminViewTests):
|
|||||||
self.assertRedirectsNoFollow(res, GROUP_MANAGE_URL)
|
self.assertRedirectsNoFollow(res, GROUP_MANAGE_URL)
|
||||||
self.assertMessageCount(success=1)
|
self.assertMessageCount(success=1)
|
||||||
|
|
||||||
|
self.mock_get_effective_domain_id.assert_called_once_with(
|
||||||
|
test.IsHttpRequest())
|
||||||
|
self.mock_group_get.assert_called_once_with(test.IsHttpRequest(),
|
||||||
|
group.id)
|
||||||
|
self.mock_user_list.assert_has_calls([
|
||||||
|
mock.call(test.IsHttpRequest(), domain=domain_id),
|
||||||
|
mock.call(test.IsHttpRequest(), domain=domain_id, group=group.id),
|
||||||
|
])
|
||||||
|
self.mock_add_group_user.assert_called_once_with(test.IsHttpRequest(),
|
||||||
|
group_id=group.id,
|
||||||
|
user_id=user.id)
|
||||||
|
|
||||||
@test.update_settings(FILTER_DATA_FIRST={'identity.groups': True})
|
@test.update_settings(FILTER_DATA_FIRST={'identity.groups': True})
|
||||||
def test_index_with_filter_first(self):
|
def test_index_with_filter_first(self):
|
||||||
res = self.client.get(GROUPS_INDEX_URL)
|
res = self.client.get(GROUPS_INDEX_URL)
|
||||||
|
Loading…
Reference in New Issue
Block a user