Convert admin.metadata_defs tests into mock

Partially-Implements: blueprint mock-framework-in-unit-tests
Change-Id: I688467f5f86ec1977ac9761cdcba23cf518ff511
This commit is contained in:
Vladislav Kuzmin 2018-03-13 10:15:50 +04:00 committed by Akihiro Motoki
parent 67df90820c
commit 68fc1c02c3

View File

@ -16,10 +16,9 @@
import json import json
from django import http
from django.urls import reverse from django.urls import reverse
from mox3.mox import IsA import mock
import six import six
from openstack_dashboard import api from openstack_dashboard import api
@ -42,57 +41,49 @@ class MetadataDefinitionsView(test.BaseAdminViewTests):
self.assertTrue(namespace.public) self.assertTrue(namespace.public)
self.assertEqual('sample', namespace.resource_type_names[0]) self.assertEqual('sample', namespace.resource_type_names[0])
@test.create_stubs({api.glance: ('metadefs_namespace_list',)}) @mock.patch.object(api.glance, 'metadefs_namespace_list')
def test_metadata_defs_list(self): def test_metadata_defs_list(self, mock_metafefs_namespace_list):
namespace_list = self.metadata_defs.list() namespace_list = self.metadata_defs.list()
api.glance.metadefs_namespace_list( mock_metafefs_namespace_list.return_value = (namespace_list,
IsA(http.HttpRequest), False, False)
sort_dir='asc',
marker=None,
paginate=True,
filters={}).AndReturn((namespace_list, False, False))
self.mox.ReplayAll()
res = self.client.get(reverse(constants.METADATA_INDEX_URL)) res = self.client.get(reverse(constants.METADATA_INDEX_URL))
self.assertTemplateUsed(res, constants.METADATA_INDEX_TEMPLATE) self.assertTemplateUsed(res, constants.METADATA_INDEX_TEMPLATE)
self.assertEqual(len(res.context['namespaces_table'].data), self.assertEqual(len(res.context['namespaces_table'].data),
len(namespace_list)) len(namespace_list))
mock_metafefs_namespace_list.assert_called_once_with(
test.IsHttpRequest(), sort_dir='asc',
marker=None, paginate=True, filters={})
@test.create_stubs({api.glance: ('metadefs_namespace_list',)}) @mock.patch.object(api.glance, 'metadefs_namespace_list')
def test_metadata_defs_no_results(self): def test_metadata_defs_no_results(self, mock_metadefs_namespace_list):
api.glance.metadefs_namespace_list( mock_metadefs_namespace_list.return_value = ((), False, False)
IsA(http.HttpRequest),
sort_dir='asc',
marker=None,
paginate=True).AndReturn(((), False, False))
self.mox.ReplayAll()
res = self.client.get(reverse(constants.METADATA_INDEX_URL)) res = self.client.get(reverse(constants.METADATA_INDEX_URL))
self.assertTemplateUsed(res, constants.METADATA_INDEX_TEMPLATE) self.assertTemplateUsed(res, constants.METADATA_INDEX_TEMPLATE)
self.assertEqual(len(res.context['namespaces_table'].data), 0) self.assertEqual(len(res.context['namespaces_table'].data), 0)
@test.create_stubs({api.glance: ('metadefs_namespace_list',)}) mock_metadefs_namespace_list.assert_called_once_with(
def test_metadata_defs_error(self): test.IsHttpRequest(), filters={}, marker=None,
api.glance.metadefs_namespace_list( paginate=True, sort_dir='asc')
IsA(http.HttpRequest),
sort_dir='asc', @mock.patch.object(api.glance, 'metadefs_namespace_list')
marker=None, def test_metadata_defs_error(self, mock_metadefs_namespace_list):
paginate=True).AndRaise(self.exceptions.glance) mock_metadefs_namespace_list.side_effect = self.exceptions.glance
self.mox.ReplayAll()
res = self.client.get(reverse(constants.METADATA_INDEX_URL)) res = self.client.get(reverse(constants.METADATA_INDEX_URL))
self.assertTemplateUsed(res, constants.METADATA_INDEX_TEMPLATE)
@test.create_stubs({api.glance: ('metadefs_namespace_list',)}) self.assertTemplateUsed(res, constants.METADATA_INDEX_TEMPLATE)
def test_delete_availability(self): mock_metadefs_namespace_list.assert_called_once_with(
namespace_list = self.metadata_defs.list() test.IsHttpRequest(), filters={}, marker=None,
api.glance.metadefs_namespace_list( paginate=True, sort_dir='asc')
IsA(http.HttpRequest),
sort_dir='asc', @mock.patch.object(api.glance, 'metadefs_namespace_list')
marker=None, def test_delete_availability(self, mock_metadefs_namespace_list):
paginate=True, mock_metadefs_namespace_list.return_value = (self.metadata_defs.list(),
filters={}).AndReturn((namespace_list, False, False)) False, False)
self.mox.ReplayAll()
res = self.client.get(reverse(constants.METADATA_INDEX_URL)) res = self.client.get(reverse(constants.METADATA_INDEX_URL))
self.assertIn('namespaces_table', res.context) self.assertIn('namespaces_table', res.context)
@ -107,15 +98,13 @@ class MetadataDefinitionsView(test.BaseAdminViewTests):
self.assertIn('manage_resource_types', self.assertIn('manage_resource_types',
[a.name for a in row_actions]) [a.name for a in row_actions])
@test.create_stubs({api.glance: ('metadefs_namespace_get',)}) mock_metadefs_namespace_list.assert_called_once_with(
def test_metadata_defs_get(self): test.IsHttpRequest(), sort_dir='asc',
namespace = self.metadata_defs.first() marker=None, paginate=True, filters={})
api.glance.metadefs_namespace_get(
IsA(http.HttpRequest), @mock.patch.object(api.glance, 'metadefs_namespace_get')
'1', def test_metadata_defs_get(self, mock_metadefs_namespace_get):
wrap=True mock_metadefs_namespace_get.return_value = self.metadata_defs.first()
).MultipleTimes().AndReturn(namespace)
self.mox.ReplayAll()
res = self.client.get(reverse(constants.METADATA_DETAIL_URL, res = self.client.get(reverse(constants.METADATA_DETAIL_URL,
kwargs={'namespace_id': '1'})) kwargs={'namespace_id': '1'}))
@ -123,15 +112,13 @@ class MetadataDefinitionsView(test.BaseAdminViewTests):
self.assertNoFormErrors(res) self.assertNoFormErrors(res)
self.assertTemplateUsed(res, constants.METADATA_DETAIL_TEMPLATE) self.assertTemplateUsed(res, constants.METADATA_DETAIL_TEMPLATE)
@test.create_stubs({api.glance: ('metadefs_namespace_get',)}) self.assert_mock_multiple_calls_with_same_arguments(
def test_metadata_defs_get_contents(self): mock_metadefs_namespace_get, 2,
namespace = self.metadata_defs.first() mock.call(test.IsHttpRequest(), '1', wrap=True))
api.glance.metadefs_namespace_get(
IsA(http.HttpRequest), @mock.patch.object(api.glance, 'metadefs_namespace_get')
'1', def test_metadata_defs_get_contents(self, mock_metadefs_namespace_get):
wrap=True mock_metadefs_namespace_get.return_value = self.metadata_defs.first()
).MultipleTimes().AndReturn(namespace)
self.mox.ReplayAll()
res = self.client.get( res = self.client.get(
'?'.join([reverse(constants.METADATA_DETAIL_URL, '?'.join([reverse(constants.METADATA_DETAIL_URL,
@ -141,15 +128,13 @@ class MetadataDefinitionsView(test.BaseAdminViewTests):
self.assertNoFormErrors(res) self.assertNoFormErrors(res)
self.assertTemplateUsed(res, constants.METADATA_DETAIL_TEMPLATE) self.assertTemplateUsed(res, constants.METADATA_DETAIL_TEMPLATE)
@test.create_stubs({api.glance: ('metadefs_namespace_get',)}) self.assert_mock_multiple_calls_with_same_arguments(
def test_metadata_defs_get_overview(self): mock_metadefs_namespace_get, 3,
namespace = self.metadata_defs.first() mock.call(test.IsHttpRequest(), '1', wrap=True))
api.glance.metadefs_namespace_get(
IsA(http.HttpRequest), @mock.patch.object(api.glance, 'metadefs_namespace_get')
'1', def test_metadata_defs_get_overview(self, mock_metadefs_namespace_get):
wrap=True mock_metadefs_namespace_get.return_value = self.metadata_defs.first()
).MultipleTimes().AndReturn(namespace)
self.mox.ReplayAll()
res = self.client.get( res = self.client.get(
'?'.join([reverse(constants.METADATA_DETAIL_URL, '?'.join([reverse(constants.METADATA_DETAIL_URL,
@ -159,18 +144,18 @@ class MetadataDefinitionsView(test.BaseAdminViewTests):
self.assertNoFormErrors(res) self.assertNoFormErrors(res)
self.assertTemplateUsed(res, constants.METADATA_DETAIL_TEMPLATE) self.assertTemplateUsed(res, constants.METADATA_DETAIL_TEMPLATE)
@test.create_stubs({api.glance: ('metadefs_resource_types_list', mock_metadefs_namespace_get.assert_has_calls([
'metadefs_namespace_resource_types')}) mock.call(test.IsHttpRequest(), '1', wrap=True)])
self.assertEqual(2, mock_metadefs_namespace_get.call_count)
@test.create_mocks({api.glance: ['metadefs_resource_types_list',
'metadefs_namespace_resource_types']})
def test_metadata_defs_manage_resource_types(self): def test_metadata_defs_manage_resource_types(self):
namespace = self.metadata_defs.first() namespace = self.metadata_defs.first()
api.glance.metadefs_namespace_resource_types( self.mock_metadefs_resource_types_list.return_value = \
IsA(http.HttpRequest), namespace.resource_type_associations
'1' self.mock_metadefs_namespace_resource_types.return_value = \
).AndReturn(namespace.resource_type_associations) namespace.resource_type_associations
api.glance.metadefs_resource_types_list(
IsA(http.HttpRequest)
).AndReturn(namespace.resource_type_associations)
self.mox.ReplayAll()
res = self.client.get( res = self.client.get(
reverse(constants.METADATA_MANAGE_RESOURCES_URL, reverse(constants.METADATA_MANAGE_RESOURCES_URL,
@ -180,9 +165,14 @@ class MetadataDefinitionsView(test.BaseAdminViewTests):
constants.METADATA_MANAGE_RESOURCES_TEMPLATE) constants.METADATA_MANAGE_RESOURCES_TEMPLATE)
self.assertContains(res, 'mock name') self.assertContains(res, 'mock name')
@test.create_stubs({api.glance: ('metadefs_namespace_resource_types', self.mock_metadefs_namespace_resource_types.assert_called_once_with(
test.IsHttpRequest(), '1')
self.mock_metadefs_resource_types_list.assert_called_once_with(
test.IsHttpRequest())
@test.create_mocks({api.glance: ['metadefs_namespace_resource_types',
'metadefs_namespace_remove_resource_type', 'metadefs_namespace_remove_resource_type',
'metadefs_namespace_add_resource_type')}) 'metadefs_namespace_add_resource_type']})
def test_metadata_defs_manage_resource_types_change(self): def test_metadata_defs_manage_resource_types_change(self):
resource_type_associations = [ resource_type_associations = [
{ {
@ -195,30 +185,12 @@ class MetadataDefinitionsView(test.BaseAdminViewTests):
'selected': True 'selected': True
} }
] ]
self.mock_metadefs_namespace_resource_types.return_value = \
api.glance.metadefs_namespace_resource_types( resource_type_associations
IsA(http.HttpRequest), self.mock_metadefs_namespace_remove_resource_type.return_value = \
'1' resource_type_associations
).AndReturn(resource_type_associations) self.mock_metadefs_namespace_add_resource_type.return_value = \
api.glance.metadefs_namespace_remove_resource_type( resource_type_associations
IsA(http.HttpRequest),
'1',
'mock1'
).AndReturn(resource_type_associations)
api.glance.metadefs_namespace_remove_resource_type(
IsA(http.HttpRequest),
'1',
'mock2'
).AndReturn(resource_type_associations)
api.glance.metadefs_namespace_add_resource_type(
IsA(http.HttpRequest),
'1',
{
'prefix': 'mock2_prefix',
'name': 'mock2'
}
).AndReturn(resource_type_associations)
self.mox.ReplayAll()
form_data = {'resource_types': json.dumps(resource_type_associations)} form_data = {'resource_types': json.dumps(resource_type_associations)}
res = self.client.post( res = self.client.post(
@ -232,6 +204,19 @@ class MetadataDefinitionsView(test.BaseAdminViewTests):
res, reverse(constants.METADATA_INDEX_URL) res, reverse(constants.METADATA_INDEX_URL)
) )
self.mock_metadefs_namespace_resource_types.assert_called_once_with(
test.IsHttpRequest(), '1')
self.mock_metadefs_namespace_remove_resource_type.assert_has_calls([
mock.call(test.IsHttpRequest(), '1', 'mock1'),
mock.call(test.IsHttpRequest(), '1', 'mock2')])
self.mock_metadefs_namespace_add_resource_type. \
assert_called_once_with(
test.IsHttpRequest(), '1',
{
'prefix': 'mock2_prefix',
'name': 'mock2'
})
class MetadataDefinitionsCreateViewTest(test.BaseAdminViewTests): class MetadataDefinitionsCreateViewTest(test.BaseAdminViewTests):
@ -239,21 +224,19 @@ class MetadataDefinitionsCreateViewTest(test.BaseAdminViewTests):
res = self.client.get(reverse(constants.METADATA_CREATE_URL)) res = self.client.get(reverse(constants.METADATA_CREATE_URL))
self.assertTemplateUsed(res, constants.METADATA_CREATE_TEMPLATE) self.assertTemplateUsed(res, constants.METADATA_CREATE_TEMPLATE)
@test.create_stubs({api.glance: ('metadefs_namespace_create',)}) @mock.patch.object(api.glance, 'metadefs_namespace_create')
def test_admin_metadata_defs_create_namespace_post(self): def test_admin_metadata_defs_create_namespace_post(
metadata = {} self, mock_metadefs_namespace_create):
metadata["namespace"] = "test_namespace" metadata = {
metadata["display_name"] = "display_name" "namespace": "test_namespace",
metadata["description"] = "description" "display_name": "display_name",
metadata["visibility"] = "private" "description": "description",
metadata["protected"] = False "visibility": "private",
"protected": False,
api.glance.metadefs_namespace_create( }
IsA(http.HttpRequest),
metadata
).AndReturn(metadata)
self.mox.ReplayAll() self.mox.ReplayAll()
mock_metadefs_namespace_create.return_value = metadata
form_data = { form_data = {
'source_type': 'raw', 'source_type': 'raw',
@ -264,6 +247,8 @@ class MetadataDefinitionsCreateViewTest(test.BaseAdminViewTests):
form_data) form_data)
self.assertNoFormErrors(res) self.assertNoFormErrors(res)
mock_metadefs_namespace_create.assert_called_once_with(
test.IsHttpRequest(), metadata)
def test_admin_metadata_defs_create_namespace_invalid_json_post_raw(self): def test_admin_metadata_defs_create_namespace_invalid_json_post_raw(self):
form_data = { form_data = {
@ -309,28 +294,26 @@ class MetadataDefinitionsCreateViewTest(test.BaseAdminViewTests):
class MetadataDefinitionsUpdateViewTest(test.BaseAdminViewTests): class MetadataDefinitionsUpdateViewTest(test.BaseAdminViewTests):
@test.create_stubs({api.glance: ('metadefs_namespace_get', )}) @mock.patch.object(api.glance, 'metadefs_namespace_get')
def test_admin_metadata_defs_update_namespace_get(self): def test_admin_metadata_defs_update_namespace_get(
self, mock_metadata_namespace_get):
namespace = self.metadata_defs.first() namespace = self.metadata_defs.first()
api.glance.metadefs_namespace_get( mock_metadata_namespace_get.return_value = namespace
IsA(http.HttpRequest),
namespace["namespace"]).AndReturn(namespace)
self.mox.ReplayAll()
res = self.client.get(reverse( res = self.client.get(reverse(
constants.METADATA_UPDATE_URL, constants.METADATA_UPDATE_URL,
args=[namespace['namespace']])) args=[namespace['namespace']]))
self.assertTemplateUsed(res, constants.METADATA_UPDATE_TEMPLATE) self.assertTemplateUsed(res, constants.METADATA_UPDATE_TEMPLATE)
mock_metadata_namespace_get.assert_called_once_with(
test.IsHttpRequest(), namespace['namespace'])
@test.create_stubs({api.glance: ('metadefs_namespace_get',)}) @mock.patch.object(api.glance, 'metadefs_namespace_get')
def test_admin_metadata_defs_update_namespace_get_exception(self): def test_admin_metadata_defs_update_namespace_get_exception(
self, mock_metadefs_namespace_get):
namespace = self.metadata_defs.first() namespace = self.metadata_defs.first()
api.glance.metadefs_namespace_get( mock_metadefs_namespace_get.side_effect = self.exceptions.glance
IsA(http.HttpRequest),
namespace["namespace"]).AndRaise(self.exceptions.glance)
self.mox.ReplayAll()
res = self.client.get(reverse( res = self.client.get(reverse(
constants.METADATA_UPDATE_URL, constants.METADATA_UPDATE_URL,
@ -338,8 +321,11 @@ class MetadataDefinitionsUpdateViewTest(test.BaseAdminViewTests):
self.assertRedirectsNoFollow(res, self.assertRedirectsNoFollow(res,
reverse(constants.METADATA_INDEX_URL)) reverse(constants.METADATA_INDEX_URL))
@test.create_stubs({api.glance: ('metadefs_namespace_get', mock_metadefs_namespace_get.assert_called_once_with(
'metadefs_namespace_update',)}) test.IsHttpRequest(), namespace['namespace'])
@test.create_mocks({api.glance: ['metadefs_namespace_get',
'metadefs_namespace_update']})
def test_admin_metadata_defs_update_namespace_post(self): def test_admin_metadata_defs_update_namespace_post(self):
namespace = self.metadata_defs.first() namespace = self.metadata_defs.first()
params = { params = {
@ -347,15 +333,8 @@ class MetadataDefinitionsUpdateViewTest(test.BaseAdminViewTests):
'protected': namespace.protected 'protected': namespace.protected
} }
api.glance.metadefs_namespace_update( self.mock_metadefs_namespace_update.return_value = namespace
IsA(http.HttpRequest), self.mock_metadefs_namespace_get.return_value = namespace
namespace.namespace,
**params).AndReturn(namespace)
api.glance.metadefs_namespace_get(
IsA(http.HttpRequest),
namespace["namespace"]).AndReturn(namespace)
self.mox.ReplayAll()
form_data = { form_data = {
'namespace_id': namespace.namespace, 'namespace_id': namespace.namespace,
@ -370,8 +349,13 @@ class MetadataDefinitionsUpdateViewTest(test.BaseAdminViewTests):
self.assertRedirectsNoFollow(res, self.assertRedirectsNoFollow(res,
reverse(constants.METADATA_INDEX_URL)) reverse(constants.METADATA_INDEX_URL))
@test.create_stubs({api.glance: ('metadefs_namespace_get', self.mock_metadefs_namespace_update.assert_called_once_with(
'metadefs_namespace_update',)}) test.IsHttpRequest(), namespace.namespace, **params)
self.mock_metadefs_namespace_get.assert_called_once_with(
test.IsHttpRequest(), namespace['namespace'])
@test.create_mocks({api.glance: ['metadefs_namespace_get',
'metadefs_namespace_update']})
def test_admin_metadata_defs_update_namespace_post_exception(self): def test_admin_metadata_defs_update_namespace_post_exception(self):
namespace = self.metadata_defs.first() namespace = self.metadata_defs.first()
params = { params = {
@ -379,15 +363,9 @@ class MetadataDefinitionsUpdateViewTest(test.BaseAdminViewTests):
'protected': namespace.protected 'protected': namespace.protected
} }
api.glance.metadefs_namespace_update( self.mock_metadefs_namespace_update.side_effect = \
IsA(http.HttpRequest), self.exceptions.glance
namespace.namespace, self.mock_metadefs_namespace_get.return_value = namespace
**params).AndRaise(self.exceptions.glance)
api.glance.metadefs_namespace_get(
IsA(http.HttpRequest),
namespace["namespace"]).AndReturn(namespace)
self.mox.ReplayAll()
form_data = { form_data = {
'namespace_id': namespace.namespace, 'namespace_id': namespace.namespace,
@ -401,3 +379,8 @@ class MetadataDefinitionsUpdateViewTest(test.BaseAdminViewTests):
self.assertRedirectsNoFollow(res, self.assertRedirectsNoFollow(res,
reverse(constants.METADATA_INDEX_URL)) reverse(constants.METADATA_INDEX_URL))
self.mock_metadefs_namespace_update.assert_called_once_with(
test.IsHttpRequest(), namespace.namespace, **params)
self.mock_metadefs_namespace_get.assert_called_once_with(
test.IsHttpRequest(), namespace['namespace'])