summaryrefslogtreecommitdiff
path: root/ironic/nova
diff options
context:
space:
mode:
authorLucas Alvares Gomes <lucasagomes@gmail.com>2014-08-12 18:05:37 +0100
committerLucas Alvares Gomes <lucasagomes@gmail.com>2014-08-12 18:15:21 +0100
commitec160684d77fccaf44953cd74e5bed0e06557bee (patch)
tree907dd450ef2b1250af58123aafd30ca8f053dff8 /ironic/nova
parent06adba3f7c6a1a5d1505c62b6e274b57ee8dd2ee (diff)
downloadironic-ec160684d77fccaf44953cd74e5bed0e06557bee.tar.gz
Import fixes from the Nova driver reviews
Import fixes from the Nova driver review, based upon revision 4 of https://review.openstack.org/#/c/111423/ - Add unittests for patcher.create() - Convert some of the tests for the PXEDriverFields to GenericDriverFields and make sure that the delta from the PXE class is covered Change-Id: Iec8d1d379458b89a2140dc473ad691dc5dd6d3dc
Diffstat (limited to 'ironic/nova')
-rw-r--r--ironic/nova/tests/virt/ironic/test_patcher.py142
1 files changed, 73 insertions, 69 deletions
diff --git a/ironic/nova/tests/virt/ironic/test_patcher.py b/ironic/nova/tests/virt/ironic/test_patcher.py
index 2f073f9d6..f9ea2b6b6 100644
--- a/ironic/nova/tests/virt/ironic/test_patcher.py
+++ b/ironic/nova/tests/virt/ironic/test_patcher.py
@@ -32,91 +32,97 @@ class IronicDriverFieldsTestCase(test.NoDBTestCase):
self.image_meta = ironic_utils.get_test_image_meta()
self.flavor = ironic_utils.get_test_flavor()
self.ctx = nova_context.get_admin_context()
+ self.instance = fake_instance.fake_instance_obj(self.ctx)
+ # Generic expected patches
+ self._expected_deploy_patch = [{'path': '/instance_info/image_source',
+ 'value': self.image_meta['id'],
+ 'op': 'add'},
+ {'path': '/instance_info/root_gb',
+ 'value': str(self.instance['root_gb']),
+ 'op': 'add'},
+ {'path': '/instance_info/swap_mb',
+ 'value': str(self.flavor['swap']),
+ 'op': 'add'}]
+ self._expected_cleanup_patch = []
- def test_pxe_get_deploy_patch(self):
+ def test_create_generic(self):
+ node = ironic_utils.get_test_node(driver='fake')
+ patcher_obj = patcher.create(node)
+ self.assertIsInstance(patcher_obj, patcher.GenericDriverFields)
+
+ def test_create_pxe(self):
node = ironic_utils.get_test_node(driver='pxe_fake')
- instance = fake_instance.fake_instance_obj(self.ctx, node=node.uuid)
- extra_specs = self.flavor['extra_specs']
- expected = [{'path': '/driver_info/pxe_deploy_kernel',
- 'value': extra_specs['baremetal:deploy_kernel_id'],
- 'op': 'add'},
- {'path': '/driver_info/pxe_deploy_ramdisk',
- 'value': extra_specs['baremetal:deploy_ramdisk_id'],
- 'op': 'add'},
- {'path': '/instance_info/image_source',
- 'value': self.image_meta['id'],
- 'op': 'add'},
- {'path': '/instance_info/root_gb',
- 'value': str(instance['root_gb']),
- 'op': 'add'},
- {'path': '/instance_info/swap_mb',
- 'value': str(self.flavor['swap']),
- 'op': 'add'}]
+ patcher_obj = patcher.create(node)
+ self.assertIsInstance(patcher_obj, patcher.PXEDriverFields)
+
+ def test_generic_get_deploy_patch(self):
+ node = ironic_utils.get_test_node(driver='fake')
patch = patcher.create(node).get_deploy_patch(
- instance, self.image_meta, self.flavor)
- self.assertEqual(sorted(expected), sorted(patch))
+ self.instance, self.image_meta, self.flavor)
+ self.assertEqual(sorted(self._expected_deploy_patch), sorted(patch))
- def test_pxe_get_deploy_patch_with_ephemeral(self):
- node = ironic_utils.get_test_node(driver='pxe_fake')
- instance = fake_instance.fake_instance_obj(
- self.ctx, node=node.uuid, ephemeral_gb=10)
+ def test_generic_get_deploy_patch_ephemeral(self):
CONF.set_override('default_ephemeral_format', 'testfmt')
+ node = ironic_utils.get_test_node(driver='fake')
+ instance = fake_instance.fake_instance_obj(self.ctx,
+ ephemeral_gb=10)
patch = patcher.create(node).get_deploy_patch(
instance, self.image_meta, self.flavor)
- expected1 = {'path': '/instance_info/ephemeral_gb',
- 'value': '10', 'op': 'add'}
- expected2 = {'path': '/instance_info/ephemeral_format',
- 'value': 'testfmt', 'op': 'add'}
- self.assertIn(expected1, patch)
- self.assertIn(expected2, patch)
-
- def test_pxe_get_deploy_patch_preserve_ephemeral(self):
- node = ironic_utils.get_test_node(driver='pxe_fake')
- instance = fake_instance.fake_instance_obj(
- self.ctx, node=node.uuid, ephemeral_gb=10)
+ expected = [{'path': '/instance_info/ephemeral_gb',
+ 'value': str(instance.ephemeral_gb),
+ 'op': 'add'},
+ {'path': '/instance_info/ephemeral_format',
+ 'value': 'testfmt',
+ 'op': 'add'}]
+ expected += self._expected_deploy_patch
+ self.assertEqual(sorted(expected), sorted(patch))
+
+ def test_generic_get_deploy_patch_preserve_ephemeral(self):
+ node = ironic_utils.get_test_node(driver='fake')
for preserve in [True, False]:
patch = patcher.create(node).get_deploy_patch(
- instance, self.image_meta, self.flavor,
+ self.instance, self.image_meta, self.flavor,
preserve_ephemeral=preserve)
- expected = {'path': '/instance_info/preserve_ephemeral',
- 'value': str(preserve), 'op': 'add', }
- self.assertIn(expected, patch)
+ expected = [{'path': '/instance_info/preserve_ephemeral',
+ 'value': str(preserve), 'op': 'add', }]
+ expected += self._expected_deploy_patch
+ self.assertEqual(sorted(expected), sorted(patch))
- def test_pxe_get_deploy_patch_no_preserve_ephemeral(self):
- node = ironic_utils.get_test_node(driver='pxe_fake')
- instance = fake_instance.fake_instance_obj(
- self.ctx, node=node.uuid, ephemeral_gb=10)
- patch = patcher.create(node).get_deploy_patch(
- instance, self.image_meta, self.flavor)
- for preserve in [True, False]:
- unexpected = {'path': '/instance_info/preserve_ephemeral',
- 'value': str(preserve), 'op': 'add', }
- self.assertNotIn(unexpected, patch)
+ def test_generic_get_cleanup_patch(self):
+ node = ironic_utils.get_test_node(driver='fake')
+ patch = patcher.create(node).get_cleanup_patch(self.instance, None,
+ self.flavor)
+ self.assertEqual(self._expected_cleanup_patch, patch)
- def test_pxe_get_deploy_patch_no_flavor_kernel_ramdisk_ids(self):
- self.flavor = ironic_utils.get_test_flavor(extra_specs={})
+ def test_pxe_get_deploy_patch(self):
node = ironic_utils.get_test_node(driver='pxe_fake')
- instance = fake_instance.fake_instance_obj(self.ctx, node=node.uuid)
- expected = [{'path': '/instance_info/image_source',
- 'value': self.image_meta['id'],
- 'op': 'add'},
- {'path': '/instance_info/root_gb',
- 'value': str(instance['root_gb']),
+ extra_specs = self.flavor['extra_specs']
+ expected = [{'path': '/driver_info/pxe_deploy_kernel',
+ 'value': extra_specs['baremetal:deploy_kernel_id'],
'op': 'add'},
- {'path': '/instance_info/swap_mb',
- 'value': str(self.flavor['swap']),
+ {'path': '/driver_info/pxe_deploy_ramdisk',
+ 'value': extra_specs['baremetal:deploy_ramdisk_id'],
'op': 'add'}]
+ expected += self._expected_deploy_patch
patch = patcher.create(node).get_deploy_patch(
- instance, self.image_meta, self.flavor)
+ self.instance, self.image_meta, self.flavor)
self.assertEqual(sorted(expected), sorted(patch))
+ def test_pxe_get_deploy_patch_no_flavor_kernel_ramdisk_ids(self):
+ flavor = ironic_utils.get_test_flavor(extra_specs={})
+ node = ironic_utils.get_test_node(driver='pxe_fake')
+ patch = patcher.create(node).get_deploy_patch(
+ self.instance, self.image_meta, flavor)
+ # If there's no extra_specs patch should be exactly like a
+ # generic patch
+ self.assertEqual(sorted(self._expected_deploy_patch), sorted(patch))
+
def test_pxe_get_cleanup_patch(self):
driver_info = {'pxe_deploy_kernel': 'fake-kernel-id',
'pxe_deploy_ramdisk': 'fake-ramdisk-id'}
node = ironic_utils.get_test_node(driver='pxe_fake',
driver_info=driver_info)
- instance = fake_instance.fake_instance_obj(self.ctx, node=node.uuid)
- patch = patcher.create(node).get_cleanup_patch(instance, None,
+ patch = patcher.create(node).get_cleanup_patch(self.instance, None,
self.flavor)
expected = [{'path': '/driver_info/pxe_deploy_kernel',
'op': 'remove'},
@@ -126,11 +132,9 @@ class IronicDriverFieldsTestCase(test.NoDBTestCase):
def test_pxe_get_cleanup_patch_no_flavor_kernel_ramdisk_ids(self):
self.flavor = ironic_utils.get_test_flavor(extra_specs={})
- driver_info = {'pxe_deploy_kernel': 'fake-kernel-id',
- 'pxe_deploy_ramdisk': 'fake-ramdisk-id'}
- node = ironic_utils.get_test_node(driver='pxe_fake',
- driver_info=driver_info)
- instance = fake_instance.fake_instance_obj(self.ctx, node=node.uuid)
- patch = patcher.create(node).get_cleanup_patch(instance, None,
+ node = ironic_utils.get_test_node(driver='pxe_fake')
+ patch = patcher.create(node).get_cleanup_patch(self.instance, None,
self.flavor)
- self.assertEqual([], patch)
+ # If there's no extra_specs patch should be exactly like a
+ # generic patch
+ self.assertEqual(self._expected_cleanup_patch, patch)