Fake missing local_gb for root_device_hint plugin

At the first run of discovery, the RAID volumes might be missing from
the node. To avoid the standard plugin erroring, root_device_hint plugin
fakes the missing local_gb value. The fake value will be overwritten
with the correct one during later runs.

Change-Id: I2d38557fa356656e44e9915d3c4a5abb9cf1731d
This commit is contained in:
Imre Farkas 2015-05-27 11:14:15 +02:00
parent d6404d2f99
commit 730b0bf34f
2 changed files with 24 additions and 0 deletions

View File

@ -37,8 +37,20 @@ class RootDeviceHintHook(base.ProcessingHook):
information about the created RAID disks. Using this plugin immediately information about the created RAID disks. Using this plugin immediately
before and after creating the root RAID device will solve the issue of root before and after creating the root RAID device will solve the issue of root
device hints. device hints.
In cases where there's no RAID volume on the node, the standard plugin will
fail due to the missing local_gb value. This plugin fakes the missing
value, until it's corrected during later runs. Note, that for this to work
the plugin needs to take precedence over the standard plugin.
""" """
def before_processing(self, node_info):
"""Adds fake local_gb value if it's missing from node_info."""
if not node_info.get('local_gb'):
LOG.info(_LI('No volume is found on the node. Adding a fake '
'value for "local_gb"'))
node_info['local_gb'] = 1
def before_update(self, node, ports, node_info): def before_update(self, node, ports, node_info):
if 'block_devices' not in node_info: if 'block_devices' not in node_info:
LOG.warning(_LW('No block device was received from ramdisk')) LOG.warning(_LW('No block device was received from ramdisk'))

View File

@ -21,6 +21,18 @@ class TestRootDeviceHint(test_base.NodeTest):
super(TestRootDeviceHint, self).setUp() super(TestRootDeviceHint, self).setUp()
self.hook = root_device_hint.RootDeviceHintHook() self.hook = root_device_hint.RootDeviceHintHook()
def test_missing_local_gb(self):
node_info = {}
self.hook.before_processing(node_info)
self.assertEqual(1, node_info['local_gb'])
def test_local_gb_not_changes(self):
node_info = {'local_gb': 42}
self.hook.before_processing(node_info)
self.assertEqual(42, node_info['local_gb'])
def test_no_previous_block_devices(self): def test_no_previous_block_devices(self):
node_info = {'block_devices': {'serials': ['foo', 'bar']}} node_info = {'block_devices': {'serials': ['foo', 'bar']}}
node_patches, _ = self.hook.before_update(self.node, None, node_info) node_patches, _ = self.hook.before_update(self.node, None, node_info)