Switch Glance API tests to mock

This patch changes mox to mock for the following test modules:
* openstack_dashboard/test/api_tests/glance_tests.py

Change-Id: I282bc6a8ceca851b9755c9637790da055e6b4780
Partially-Implements: blueprint mock-framework-in-unit-tests
This commit is contained in:
Ivan Kolodyazhny 2017-12-26 14:06:38 +02:00
parent fb9699f34c
commit ec0b29f996
2 changed files with 105 additions and 98 deletions

View File

@ -485,6 +485,9 @@ class APITestCase(TestCase):
return self.keystoneclient return self.keystoneclient
def stub_glanceclient(self): def stub_glanceclient(self):
LOG.warning("APITestCase has been deprecated for Glance-related "
"tests and will be removerd in 'S' release. Please "
"convert your to use APIMockTestCase instead.")
if not hasattr(self, "glanceclient"): if not hasattr(self, "glanceclient"):
self.mox.StubOutWithMock(glanceclient, 'Client') self.mox.StubOutWithMock(glanceclient, 'Client')
self.glanceclient = self.mox.CreateMock(glanceclient.Client) self.glanceclient = self.mox.CreateMock(glanceclient.Client)
@ -520,6 +523,11 @@ class APIMockTestCase(APITestCase):
self.cinderclient = mock.Mock() self.cinderclient = mock.Mock()
return self.cinderclient return self.cinderclient
def stub_glanceclient(self):
if not hasattr(self, "glanceclient"):
self.glanceclient = mock.Mock()
return self.glanceclient
# Need this to test both Glance API V1 and V2 versions # Need this to test both Glance API V1 and V2 versions
class ResetImageAPIVersionMixin(object): class ResetImageAPIVersionMixin(object):

View File

@ -18,13 +18,14 @@
from django.conf import settings from django.conf import settings
from django.test.utils import override_settings from django.test.utils import override_settings
import mock
from openstack_dashboard import api from openstack_dashboard import api
from openstack_dashboard.api import base from openstack_dashboard.api import base
from openstack_dashboard.test import helpers as test from openstack_dashboard.test import helpers as test
class GlanceApiTests(test.APITestCase): class GlanceApiTests(test.APIMockTestCase):
def setUp(self): def setUp(self):
super(GlanceApiTests, self).setUp() super(GlanceApiTests, self).setUp()
api.glance.VERSIONS.clear_active_cache() api.glance.VERSIONS.clear_active_cache()
@ -38,18 +39,17 @@ class GlanceApiTests(test.APITestCase):
limit = getattr(settings, 'API_RESULT_LIMIT', 1000) limit = getattr(settings, 'API_RESULT_LIMIT', 1000)
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_images_list = glanceclient.images.list
glanceclient.images.list(page_size=limit, mock_images_list.return_value = iter(api_images)
limit=limit,
filters=filters,
sort_dir='desc',
sort_key='created_at',) \
.AndReturn(iter(api_images))
self.mox.ReplayAll()
images, has_more, has_prev = api.glance.image_list_detailed( images, has_more, has_prev = api.glance.image_list_detailed(
self.request) self.request)
mock_images_list.assert_called_once_with(page_size=limit,
limit=limit,
filters=filters,
sort_dir='desc',
sort_key='created_at')
self.assertListEqual(images, expected_images) self.assertListEqual(images, expected_images)
self.assertFalse(has_more) self.assertFalse(has_more)
self.assertFalse(has_prev) self.assertFalse(has_prev)
@ -65,19 +65,19 @@ class GlanceApiTests(test.APITestCase):
sort_key = 'min_disk' sort_key = 'min_disk'
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_images_list = glanceclient.images.list
glanceclient.images.list(page_size=limit, mock_images_list.return_value = iter(api_images)
limit=limit,
filters=filters,
sort_dir=sort_dir,
sort_key=sort_key) \
.AndReturn(iter(api_images))
self.mox.ReplayAll()
images, has_more, has_prev = api.glance.image_list_detailed( images, has_more, has_prev = api.glance.image_list_detailed(
self.request, self.request,
sort_dir=sort_dir, sort_dir=sort_dir,
sort_key=sort_key) sort_key=sort_key)
mock_images_list.assert_called_once_with(page_size=limit,
limit=limit,
filters=filters,
sort_dir=sort_dir,
sort_key=sort_key)
self.assertListEqual(images, expected_images) self.assertListEqual(images, expected_images)
self.assertFalse(has_more) self.assertFalse(has_more)
self.assertFalse(has_prev) self.assertFalse(has_prev)
@ -95,21 +95,23 @@ class GlanceApiTests(test.APITestCase):
images_iter = iter(api_images) images_iter = iter(api_images)
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_images_list = glanceclient.images.list
# Pass back all images, ignoring filters mock_images_list.return_value = images_iter
glanceclient.images.list(limit=limit,
page_size=page_size + 1,
filters=filters,
sort_dir='desc',
sort_key='created_at',).AndReturn(images_iter)
self.mox.ReplayAll()
# Pass back all images, ignoring filters
images, has_more, has_prev = api.glance.image_list_detailed( images, has_more, has_prev = api.glance.image_list_detailed(
self.request, self.request,
marker=None, marker=None,
filters=filters, filters=filters,
paginate=True) paginate=True)
expected_images = expected_images[:page_size] expected_images = expected_images[:page_size]
mock_images_list.assert_called_once_with(limit=limit,
page_size=page_size + 1,
filters=filters,
sort_dir='desc',
sort_key='created_at')
self.assertListEqual(images, expected_images) self.assertListEqual(images, expected_images)
self.assertTrue(has_more) self.assertTrue(has_more)
self.assertFalse(has_prev) self.assertFalse(has_prev)
@ -128,23 +130,24 @@ class GlanceApiTests(test.APITestCase):
api_images = self.images_api.list() api_images = self.images_api.list()
expected_images = self.images.list() # Wrapped Images expected_images = self.images.list() # Wrapped Images
images_iter = iter(api_images)
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_images_list = glanceclient.images.list
# Pass back all images, ignoring filters mock_images_list.return_value = iter(api_images)
glanceclient.images.list(limit=limit,
page_size=page_size + 1,
filters=filters,
sort_dir='desc',
sort_key='created_at',).AndReturn(images_iter)
self.mox.ReplayAll()
# Pass back all images, ignoring filters
images, has_more, has_prev = api.glance.image_list_detailed( images, has_more, has_prev = api.glance.image_list_detailed(
self.request, self.request,
filters=filters, filters=filters,
paginate=True) paginate=True)
expected_images = expected_images[:page_size] expected_images = expected_images[:page_size]
mock_images_list.assert_called_once_with(limit=limit,
page_size=page_size + 1,
filters=filters,
sort_dir='desc',
sort_key='created_at')
self.assertListEqual(images, expected_images) self.assertListEqual(images, expected_images)
self.assertFalse(has_more) self.assertFalse(has_more)
self.assertFalse(has_prev) self.assertFalse(has_prev)
@ -159,22 +162,23 @@ class GlanceApiTests(test.APITestCase):
api_images = self.images_api.list() api_images = self.images_api.list()
expected_images = self.images.list() # Wrapped Images expected_images = self.images.list() # Wrapped Images
images_iter = iter(api_images)
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_images_list = glanceclient.images.list
glanceclient.images.list(limit=limit, mock_images_list.return_value = iter(api_images)
page_size=page_size + 1,
filters=filters,
sort_dir='desc',
sort_key='created_at',).AndReturn(images_iter)
self.mox.ReplayAll()
images, has_more, has_prev = api.glance.image_list_detailed( images, has_more, has_prev = api.glance.image_list_detailed(
self.request, self.request,
filters=filters, filters=filters,
paginate=True) paginate=True)
expected_images = expected_images[:page_size] expected_images = expected_images[:page_size]
mock_images_list.assert_called_once_with(limit=limit,
page_size=page_size + 1,
filters=filters,
sort_dir='desc',
sort_key='created_at')
self.assertListEqual(images, expected_images) self.assertListEqual(images, expected_images)
self.assertFalse(has_more) self.assertFalse(has_more)
self.assertFalse(has_prev) self.assertFalse(has_prev)
@ -193,23 +197,24 @@ class GlanceApiTests(test.APITestCase):
images_iter = iter(api_images) images_iter = iter(api_images)
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_images_list = glanceclient.images.list
# Pass back all images, ignoring filters mock_images_list.return_value = images_iter
glanceclient.images.list(limit=limit,
page_size=page_size + 1,
filters=filters,
marker=marker,
sort_dir='desc',
sort_key='created_at',) \
.AndReturn(images_iter)
self.mox.ReplayAll()
# Pass back all images, ignoring filters
images, has_more, has_prev = api.glance.image_list_detailed( images, has_more, has_prev = api.glance.image_list_detailed(
self.request, self.request,
marker=marker, marker=marker,
filters=filters, filters=filters,
paginate=True) paginate=True)
expected_images = expected_images[:page_size] expected_images = expected_images[:page_size]
mock_images_list.assert_called_once_with(limit=limit,
page_size=page_size + 1,
filters=filters,
marker=marker,
sort_dir='desc',
sort_key='created_at')
self.assertListEqual(images, expected_images) self.assertListEqual(images, expected_images)
self.assertTrue(has_more) self.assertTrue(has_more)
self.assertTrue(has_prev) self.assertTrue(has_prev)
@ -229,24 +234,25 @@ class GlanceApiTests(test.APITestCase):
images_iter = iter(api_images) images_iter = iter(api_images)
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_images_list = glanceclient.images.list
# Pass back all images, ignoring filters mock_images_list.return_value = images_iter
glanceclient.images.list(limit=limit,
page_size=page_size + 1,
marker=marker,
filters=filters,
sort_dir='asc',
sort_key='created_at',) \
.AndReturn(images_iter)
self.mox.ReplayAll()
# Pass back all images, ignoring filters
images, has_more, has_prev = api.glance.image_list_detailed( images, has_more, has_prev = api.glance.image_list_detailed(
self.request, self.request,
marker=marker, marker=marker,
filters=filters, filters=filters,
sort_dir='asc', sort_dir='asc',
paginate=True) paginate=True)
expected_images = expected_images[:page_size] expected_images = expected_images[:page_size]
mock_images_list.assert_called_once_with(limit=limit,
page_size=page_size + 1,
marker=marker,
filters=filters,
sort_dir='asc',
sort_key='created_at')
self.assertListEqual(images, expected_images) self.assertListEqual(images, expected_images)
self.assertTrue(has_more) self.assertTrue(has_more)
self.assertTrue(has_prev) self.assertTrue(has_prev)
@ -255,10 +261,12 @@ class GlanceApiTests(test.APITestCase):
def test_get_image_empty_name(self): def test_get_image_empty_name(self):
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_images_get = glanceclient.images.get
glanceclient.images.get('empty').AndReturn(self.empty_name_image) mock_images_get.return_value = self.empty_name_image
self.mox.ReplayAll()
image = api.glance.image_get(self.request, 'empty') image = api.glance.image_get(self.request, 'empty')
mock_images_get.assert_called_once_with('empty')
self.assertIsNone(image.name) self.assertIsNone(image.name)
def test_metadefs_namespace_list(self): def test_metadefs_namespace_list(self):
@ -266,17 +274,16 @@ class GlanceApiTests(test.APITestCase):
limit = getattr(settings, 'API_RESULT_LIMIT', 1000) limit = getattr(settings, 'API_RESULT_LIMIT', 1000)
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.metadefs_namespace = self.mox.CreateMockAnything() mock_metadefs_list = glanceclient.metadefs_namespace.list
glanceclient.metadefs_namespace.list(page_size=limit, mock_metadefs_list.return_value = metadata_defs
limit=limit,
filters={},
sort_dir='asc',
sort_key='namespace',) \
.AndReturn(metadata_defs)
self.mox.ReplayAll()
defs, more, prev = api.glance.metadefs_namespace_list(self.request) defs, more, prev = api.glance.metadefs_namespace_list(self.request)
mock_metadefs_list.assert_called_once_with(page_size=limit,
limit=limit,
filters={},
sort_dir='asc',
sort_key='namespace')
self.assertEqual(len(metadata_defs), len(defs)) self.assertEqual(len(metadata_defs), len(defs))
for i in range(len(metadata_defs)): for i in range(len(metadata_defs)):
self.assertEqual(metadata_defs[i].namespace, defs[i].namespace) self.assertEqual(metadata_defs[i].namespace, defs[i].namespace)
@ -290,38 +297,29 @@ class GlanceApiTests(test.APITestCase):
'properties_target': 'user'} 'properties_target': 'user'}
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.metadefs_namespace = self.mox.CreateMockAnything() mock_metadefs_list = glanceclient.metadefs_namespace.list
glanceclient.metadefs_namespace.list(page_size=limit, mock_metadefs_list.return_value = metadata_defs
limit=limit,
filters=filters,
sort_dir='asc',
sort_key='namespace', ) \
.AndReturn(metadata_defs)
self.mox.ReplayAll()
defs = api.glance.metadefs_namespace_list(self.request, defs = api.glance.metadefs_namespace_list(self.request,
filters=filters)[0] filters=filters)[0]
mock_metadefs_list.assert_called_once_with(page_size=limit,
limit=limit,
filters=filters,
sort_dir='asc',
sort_key='namespace')
self.assertEqual(1, len(defs)) self.assertEqual(1, len(defs))
self.assertEqual('namespace_4', defs[0].namespace) self.assertEqual('namespace_4', defs[0].namespace)
@test.create_stubs({api.glance: ('get_version',)}) @mock.patch.object(api.glance, 'get_version', return_value=1)
def test_metadefs_namespace_list_v1(self): def test_metadefs_namespace_list_v1(self, mock_version):
api.glance.get_version().AndReturn(1)
self.mox.ReplayAll()
defs, more, prev = api.glance.metadefs_namespace_list(self.request) defs, more, prev = api.glance.metadefs_namespace_list(self.request)
self.assertItemsEqual(defs, []) self.assertItemsEqual(defs, [])
self.assertFalse(more) self.assertFalse(more)
self.assertFalse(prev) self.assertFalse(prev)
@test.create_stubs({api.glance: ('get_version',)}) @mock.patch.object(api.glance, 'get_version', return_value=1)
def test_metadefs_resource_types_list_v1(self): def test_metadefs_resource_types_list_v1(self, mock_version):
api.glance.get_version().AndReturn(1)
self.mox.ReplayAll()
res_types = api.glance.metadefs_resource_types_list(self.request) res_types = api.glance.metadefs_resource_types_list(self.request)
self.assertItemsEqual(res_types, []) self.assertItemsEqual(res_types, [])
@ -336,11 +334,12 @@ class GlanceApiTests(test.APITestCase):
upload_url = url_template % (base_url, expected_image.id) upload_url = url_template % (base_url, expected_image.id)
glanceclient = self.stub_glanceclient() glanceclient = self.stub_glanceclient()
glanceclient.images = self.mox.CreateMockAnything() mock_image_create = glanceclient.images.create
glanceclient.images.create().AndReturn(expected_image) mock_image_create.return_value = expected_image
self.mox.ReplayAll()
actual_image = api.glance.image_create(self.request, data='sample.iso') actual_image = api.glance.image_create(self.request, data='sample.iso')
mock_image_create.assert_called_once()
self.assertEqual(upload_url, actual_image.upload_url) self.assertEqual(upload_url, actual_image.upload_url)
self.assertEqual(self.request.user.token.id, actual_image.token_id) self.assertEqual(self.request.user.token.id, actual_image.token_id)