Merge "Re-base placement object unit tests on NoDBTestCase"
This commit is contained in:
commit
f7746acd8a
@ -22,7 +22,6 @@ from nova import context
|
|||||||
from nova.db.sqlalchemy import api_models as models
|
from nova.db.sqlalchemy import api_models as models
|
||||||
from nova import rc_fields as fields
|
from nova import rc_fields as fields
|
||||||
from nova import test
|
from nova import test
|
||||||
from nova.tests.unit.objects import test_objects
|
|
||||||
from nova.tests import uuidsentinel as uuids
|
from nova.tests import uuidsentinel as uuids
|
||||||
|
|
||||||
|
|
||||||
@ -92,8 +91,20 @@ def _fake_ensure_cache(ctxt):
|
|||||||
cache.id_from_string.return_value = _RESOURCE_CLASS_ID
|
cache.id_from_string.return_value = _RESOURCE_CLASS_ID
|
||||||
|
|
||||||
|
|
||||||
class TestResourceProviderNoDB(test_objects._LocalTest):
|
class _TestCase(test.NoDBTestCase):
|
||||||
USES_DB = False
|
"""Base class for other tests in this file.
|
||||||
|
|
||||||
|
It establishes the RequestContext used as self.context in the tests.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(_TestCase, self).setUp()
|
||||||
|
self.user_id = 'fake-user'
|
||||||
|
self.project_id = 'fake-project'
|
||||||
|
self.context = context.RequestContext(self.user_id, self.project_id)
|
||||||
|
|
||||||
|
|
||||||
|
class TestResourceProviderNoDB(_TestCase):
|
||||||
|
|
||||||
def test_create_id_fail(self):
|
def test_create_id_fail(self):
|
||||||
obj = resource_provider.ResourceProvider(context=self.context,
|
obj = resource_provider.ResourceProvider(context=self.context,
|
||||||
@ -119,8 +130,7 @@ class TestResourceProviderNoDB(test_objects._LocalTest):
|
|||||||
self.assertIn('root provider UUID cannot be manually set', str(exc))
|
self.assertIn('root provider UUID cannot be manually set', str(exc))
|
||||||
|
|
||||||
|
|
||||||
class TestProviderSummaryNoDB(test_objects._LocalTest):
|
class TestProviderSummaryNoDB(_TestCase):
|
||||||
USES_DB = False
|
|
||||||
|
|
||||||
def test_resource_class_names(self):
|
def test_resource_class_names(self):
|
||||||
psum = resource_provider.ProviderSummary(mock.sentinel.ctx)
|
psum = resource_provider.ProviderSummary(mock.sentinel.ctx)
|
||||||
@ -135,7 +145,9 @@ class TestProviderSummaryNoDB(test_objects._LocalTest):
|
|||||||
self.assertEqual(expected, psum.resource_class_names)
|
self.assertEqual(expected, psum.resource_class_names)
|
||||||
|
|
||||||
|
|
||||||
class TestResourceProvider(test_objects._LocalTest):
|
# FIXME(cdent): Tests which use the database aren't unit tests.
|
||||||
|
class TestResourceProvider(_TestCase):
|
||||||
|
USES_DB = True
|
||||||
|
|
||||||
def test_create_no_parent(self):
|
def test_create_no_parent(self):
|
||||||
rp = resource_provider.ResourceProvider(
|
rp = resource_provider.ResourceProvider(
|
||||||
@ -244,8 +256,7 @@ class TestResourceProvider(test_objects._LocalTest):
|
|||||||
rp.destroy()
|
rp.destroy()
|
||||||
|
|
||||||
|
|
||||||
class TestInventoryNoDB(test_objects._LocalTest):
|
class TestInventoryNoDB(_TestCase):
|
||||||
USES_DB = False
|
|
||||||
|
|
||||||
@mock.patch('nova.api.openstack.placement.objects.resource_provider.'
|
@mock.patch('nova.api.openstack.placement.objects.resource_provider.'
|
||||||
'_ensure_rc_cache', side_effect=_fake_ensure_cache)
|
'_ensure_rc_cache', side_effect=_fake_ensure_cache)
|
||||||
@ -315,7 +326,7 @@ class TestInventoryNoDB(test_objects._LocalTest):
|
|||||||
self.assertEqual(2, inv.capacity)
|
self.assertEqual(2, inv.capacity)
|
||||||
|
|
||||||
|
|
||||||
class TestInventoryList(test_objects._LocalTest):
|
class TestInventoryList(_TestCase):
|
||||||
|
|
||||||
def test_find(self):
|
def test_find(self):
|
||||||
rp = resource_provider.ResourceProvider(uuid=uuids.rp_uuid)
|
rp = resource_provider.ResourceProvider(uuid=uuids.rp_uuid)
|
||||||
@ -348,7 +359,8 @@ class TestInventoryList(test_objects._LocalTest):
|
|||||||
self.assertIsNone(inv_list.find('HOUSE'))
|
self.assertIsNone(inv_list.find('HOUSE'))
|
||||||
|
|
||||||
|
|
||||||
class TestAllocation(test_objects._LocalTest):
|
# FIXME(cdent): Tests which use the database aren't unit tests.
|
||||||
|
class TestAllocation(_TestCase):
|
||||||
USES_DB = True
|
USES_DB = True
|
||||||
|
|
||||||
@mock.patch('nova.api.openstack.placement.objects.resource_provider.'
|
@mock.patch('nova.api.openstack.placement.objects.resource_provider.'
|
||||||
@ -440,8 +452,7 @@ class TestAllocation(test_objects._LocalTest):
|
|||||||
alloc_list.create_all)
|
alloc_list.create_all)
|
||||||
|
|
||||||
|
|
||||||
class TestAllocationListNoDB(test_objects._LocalTest):
|
class TestAllocationListNoDB(_TestCase):
|
||||||
USES_DB = False
|
|
||||||
|
|
||||||
@mock.patch('nova.api.openstack.placement.objects.resource_provider.'
|
@mock.patch('nova.api.openstack.placement.objects.resource_provider.'
|
||||||
'_ensure_rc_cache',
|
'_ensure_rc_cache',
|
||||||
@ -463,13 +474,7 @@ class TestAllocationListNoDB(test_objects._LocalTest):
|
|||||||
self.assertEqual(_ALLOCATION_DB['used'], allocations[0].used)
|
self.assertEqual(_ALLOCATION_DB['used'], allocations[0].used)
|
||||||
|
|
||||||
|
|
||||||
class TestResourceClass(test.NoDBTestCase):
|
class TestResourceClass(_TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
super(TestResourceClass, self).setUp()
|
|
||||||
self.user_id = 'fake-user'
|
|
||||||
self.project_id = 'fake-project'
|
|
||||||
self.context = context.RequestContext(self.user_id, self.project_id)
|
|
||||||
|
|
||||||
def test_cannot_create_with_id(self):
|
def test_cannot_create_with_id(self):
|
||||||
rc = resource_provider.ResourceClass(self.context, id=1,
|
rc = resource_provider.ResourceClass(self.context, id=1,
|
||||||
@ -483,13 +488,7 @@ class TestResourceClass(test.NoDBTestCase):
|
|||||||
self.assertIn('name is required', str(exc))
|
self.assertIn('name is required', str(exc))
|
||||||
|
|
||||||
|
|
||||||
class TestTraits(test.NoDBTestCase):
|
class TestTraits(_TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
super(TestTraits, self).setUp()
|
|
||||||
self.user_id = 'fake-user'
|
|
||||||
self.project_id = 'fake-project'
|
|
||||||
self.context = context.RequestContext(self.user_id, self.project_id)
|
|
||||||
|
|
||||||
@mock.patch("nova.api.openstack.placement.objects.resource_provider."
|
@mock.patch("nova.api.openstack.placement.objects.resource_provider."
|
||||||
"_trait_sync")
|
"_trait_sync")
|
||||||
|
Loading…
Reference in New Issue
Block a user