Clean up vendor prefixes for iRMC boot

Generic fields, such as deploy_iso, should not have vendor prefixes.
This patch removes them from the iRMC boot interfaces with deprecation.

Change-Id: Ie24de1893395dca0e2dc4a57a42916f075d29ce6
Story: #2008880
Task: #42431
This commit is contained in:
Dmitry Tantsur 2021-06-17 17:10:37 +02:00
parent e84b6d1020
commit fc27710fa4
5 changed files with 151 additions and 98 deletions

View File

@ -2425,7 +2425,7 @@ function enroll_nodes {
--driver-info irmc_password=$bmc_passwd \ --driver-info irmc_password=$bmc_passwd \
--driver-info irmc_username=$bmc_username" --driver-info irmc_username=$bmc_username"
if [[ -n "$IRONIC_DEPLOY_ISO_ID" ]]; then if [[ -n "$IRONIC_DEPLOY_ISO_ID" ]]; then
node_options+=" --driver-info irmc_deploy_iso=$IRONIC_DEPLOY_ISO_ID" node_options+=" --driver-info deploy_iso=$IRONIC_DEPLOY_ISO_ID"
fi fi
elif is_deployed_by_xclarity; then elif is_deployed_by_xclarity; then
local xclarity_hardware_id local xclarity_hardware_id

View File

@ -129,12 +129,17 @@ Node configuration
* The following properties are also required if ``irmc-virtual-media`` boot * The following properties are also required if ``irmc-virtual-media`` boot
interface is used: interface is used:
- ``driver_info/irmc_deploy_iso`` property to be either deploy iso - ``driver_info/deploy_iso`` property to be either deploy iso
file name, Glance UUID, or Image Service URL. file name, Glance UUID, or Image Service URL.
- ``instance info/irmc_boot_iso`` property to be either boot iso - ``instance info/boot_iso`` property to be either boot iso
file name, Glance UUID, or Image Service URL. This is optional file name, Glance UUID, or Image Service URL. This is optional
property when ``boot_option`` is set to ``netboot``. property when ``boot_option`` is set to ``netboot``.
.. note::
The ``deploy_iso`` and ``boot_iso`` properties used to be called
``irmc_deploy_iso`` and ``irmc_boot_iso`` accordingly before the Xena
release.
* All of the nodes are configured by setting the following configuration * All of the nodes are configured by setting the following configuration
options in the ``[irmc]`` section of ``/etc/ironic/ironic.conf``: options in the ``[irmc]`` section of ``/etc/ironic/ironic.conf``:

View File

@ -58,14 +58,13 @@ LOG = logging.getLogger(__name__)
METRICS = metrics_utils.get_metrics_logger(__name__) METRICS = metrics_utils.get_metrics_logger(__name__)
REQUIRED_PROPERTIES = { REQUIRED_PROPERTIES = {
'irmc_deploy_iso': _("Deployment ISO image file name. " 'deploy_iso': _("Deployment ISO image file name. Required."),
"Required."),
} }
RESCUE_PROPERTIES = { RESCUE_PROPERTIES = {
'irmc_rescue_iso': _("UUID (from Glance) of the rescue ISO. Only " 'rescue_iso': _("UUID (from Glance) of the rescue ISO. Only "
"required if rescue mode is being used and ironic " "required if rescue mode is being used and ironic "
"is managing booting the rescue ramdisk.") "is managing booting the rescue ramdisk.")
} }
OPTIONAL_PROPERTIES = { OPTIONAL_PROPERTIES = {
@ -146,15 +145,11 @@ def _parse_driver_info(node, mode='deploy'):
:raises: InvalidParameterValue, if any of the parameters have invalid :raises: InvalidParameterValue, if any of the parameters have invalid
value. value.
""" """
d_info = node.driver_info
deploy_info = {} deploy_info = {}
if mode == 'deploy': image_iso = driver_utils.get_agent_iso(node, mode,
image_iso = d_info.get('irmc_deploy_iso') deprecated_prefix='irmc')
deploy_info['irmc_deploy_iso'] = image_iso deploy_info[f'{mode}_iso'] = image_iso
else:
image_iso = d_info.get('irmc_rescue_iso')
deploy_info['irmc_rescue_iso'] = image_iso
error_msg = (_("Error validating iRMC virtual media for %s. Some " error_msg = (_("Error validating iRMC virtual media for %s. Some "
"parameters were missing in node's driver_info") % mode) "parameters were missing in node's driver_info") % mode)
@ -195,16 +190,17 @@ def _parse_instance_info(node):
:raises: InvalidParameterValue, if any of the parameters have invalid :raises: InvalidParameterValue, if any of the parameters have invalid
value. value.
""" """
i_info = node.instance_info
deploy_info = {} deploy_info = {}
if i_info.get('irmc_boot_iso'): boot_iso = driver_utils.get_field(node, 'boot_iso',
deploy_info['irmc_boot_iso'] = i_info['irmc_boot_iso'] deprecated_prefix='irmc',
collection='instance_info')
if boot_iso:
deploy_info['boot_iso'] = boot_iso
if _is_image_href_ordinary_file_name( if _is_image_href_ordinary_file_name(boot_iso):
deploy_info['irmc_boot_iso']):
boot_iso = os.path.join(CONF.irmc.remote_image_share_root, boot_iso = os.path.join(CONF.irmc.remote_image_share_root,
deploy_info['irmc_boot_iso']) boot_iso)
if not os.path.isfile(boot_iso): if not os.path.isfile(boot_iso):
msg = (_("Boot ISO file, %(boot_iso)s, " msg = (_("Boot ISO file, %(boot_iso)s, "
@ -256,11 +252,7 @@ def _setup_vmedia(task, mode, ramdisk_options):
:raises: InvalidParameterValue if the validation of the :raises: InvalidParameterValue if the validation of the
PowerInterface or ManagementInterface fails. PowerInterface or ManagementInterface fails.
""" """
iso = driver_utils.get_agent_iso(task.node, mode, deprecated_prefix='irmc')
if mode == 'rescue':
iso = task.node.driver_info['irmc_rescue_iso']
else:
iso = task.node.driver_info['irmc_deploy_iso']
if _is_image_href_ordinary_file_name(iso): if _is_image_href_ordinary_file_name(iso):
iso_file = iso iso_file = iso
@ -299,17 +291,17 @@ def _prepare_boot_iso(task, root_uuid):
driver_internal_info = task.node.driver_internal_info driver_internal_info = task.node.driver_internal_info
# fetch boot iso # fetch boot iso
if deploy_info.get('irmc_boot_iso'): if deploy_info.get('boot_iso'):
boot_iso_href = deploy_info['irmc_boot_iso'] boot_iso_href = deploy_info['boot_iso']
if _is_image_href_ordinary_file_name(boot_iso_href): if _is_image_href_ordinary_file_name(boot_iso_href):
driver_internal_info['irmc_boot_iso'] = boot_iso_href driver_internal_info['boot_iso'] = boot_iso_href
else: else:
boot_iso_filename = _get_iso_name(task.node, label='boot') boot_iso_filename = _get_iso_name(task.node, label='boot')
boot_iso_fullpathname = os.path.join( boot_iso_fullpathname = os.path.join(
CONF.irmc.remote_image_share_root, boot_iso_filename) CONF.irmc.remote_image_share_root, boot_iso_filename)
images.fetch(task.context, boot_iso_href, boot_iso_fullpathname) images.fetch(task.context, boot_iso_href, boot_iso_fullpathname)
driver_internal_info['irmc_boot_iso'] = boot_iso_filename driver_internal_info['boot_iso'] = boot_iso_filename
# create boot iso # create boot iso
else: else:
@ -322,7 +314,7 @@ def _prepare_boot_iso(task, root_uuid):
ramdisk_href = (task.node.instance_info.get('ramdisk') ramdisk_href = (task.node.instance_info.get('ramdisk')
or image_properties['ramdisk_id']) or image_properties['ramdisk_id'])
deploy_iso_href = deploy_info['irmc_deploy_iso'] deploy_iso_href = deploy_info['deploy_iso']
boot_mode = boot_mode_utils.get_boot_mode(task.node) boot_mode = boot_mode_utils.get_boot_mode(task.node)
kernel_params = deploy_info['kernel_append_params'] kernel_params = deploy_info['kernel_append_params']
@ -337,9 +329,9 @@ def _prepare_boot_iso(task, root_uuid):
kernel_params=kernel_params, kernel_params=kernel_params,
boot_mode=boot_mode) boot_mode=boot_mode)
driver_internal_info['irmc_boot_iso'] = boot_iso_filename driver_internal_info['boot_iso'] = boot_iso_filename
# save driver_internal_info['irmc_boot_iso'] # save driver_internal_info['boot_iso']
task.node.driver_internal_info = driver_internal_info task.node.driver_internal_info = driver_internal_info
task.node.save() task.node.save()
@ -388,7 +380,7 @@ def attach_boot_iso_if_needed(task):
"""Attaches boot ISO for a deployed node if it exists. """Attaches boot ISO for a deployed node if it exists.
This method checks the instance info of the bare metal node for a This method checks the instance info of the bare metal node for a
boot ISO. If the instance info has a value of key 'irmc_boot_iso', boot ISO. If the instance info has a value of key 'boot_iso',
it indicates that 'boot_option' is 'netboot'. Threfore it attaches it indicates that 'boot_option' is 'netboot'. Threfore it attaches
the boot ISO on the bare metal node and then sets the node to boot from the boot ISO on the bare metal node and then sets the node to boot from
virtual media cdrom. virtual media cdrom.
@ -401,8 +393,10 @@ def attach_boot_iso_if_needed(task):
d_info = task.node.driver_internal_info d_info = task.node.driver_internal_info
node_state = task.node.provision_state node_state = task.node.provision_state
if 'irmc_boot_iso' in d_info and node_state == states.ACTIVE: # Internal field, no deprecation
_setup_vmedia_for_boot(task, d_info['irmc_boot_iso']) boot_iso = d_info.get('boot_iso') or d_info.get('irmc_boot_iso')
if boot_iso and node_state == states.ACTIVE:
_setup_vmedia_for_boot(task, boot_iso)
manager_utils.node_set_boot_device(task, boot_devices.CDROM) manager_utils.node_set_boot_device(task, boot_devices.CDROM)
@ -1087,6 +1081,7 @@ class IRMCVirtualMediaBoot(base.BootInterface, IRMCVolumeBootMixIn):
_remove_share_file(_get_iso_name(task.node, label='boot')) _remove_share_file(_get_iso_name(task.node, label='boot'))
driver_internal_info = task.node.driver_internal_info driver_internal_info = task.node.driver_internal_info
driver_internal_info.pop('boot_iso', None)
driver_internal_info.pop('irmc_boot_iso', None) driver_internal_info.pop('irmc_boot_iso', None)
task.node.driver_internal_info = driver_internal_info task.node.driver_internal_info = driver_internal_info
@ -1098,7 +1093,7 @@ class IRMCVirtualMediaBoot(base.BootInterface, IRMCVolumeBootMixIn):
node = task.node node = task.node
_prepare_boot_iso(task, root_uuid_or_disk_id) _prepare_boot_iso(task, root_uuid_or_disk_id)
_setup_vmedia_for_boot( _setup_vmedia_for_boot(
task, node.driver_internal_info['irmc_boot_iso']) task, node.driver_internal_info['boot_iso'])
manager_utils.node_set_boot_device(task, boot_devices.CDROM, manager_utils.node_set_boot_device(task, boot_devices.CDROM,
persistent=True) persistent=True)

View File

@ -105,11 +105,29 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
@mock.patch.object(os.path, 'isfile', spec_set=True, autospec=True) @mock.patch.object(os.path, 'isfile', spec_set=True, autospec=True)
def test__parse_driver_info_in_share(self, isfile_mock, def test__parse_driver_info_in_share(self, isfile_mock,
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
"""With required 'deploy_iso' in share."""
isfile_mock.return_value = True
self.node.driver_info['deploy_iso'] = 'deploy.iso'
driver_info_expected = {
'deploy_iso': 'deploy.iso',
'kernel_append_params': CONF.pxe.kernel_append_params,
}
driver_info_actual = irmc_boot._parse_driver_info(self.node,
mode='deploy')
isfile_mock.assert_called_once_with(
'/remote_image_share_root/deploy.iso')
self.assertEqual(driver_info_expected, driver_info_actual)
@mock.patch.object(os.path, 'isfile', spec_set=True, autospec=True)
def test__parse_driver_info_deprecated(self, isfile_mock,
check_share_fs_mounted_mock):
"""With required 'irmc_deploy_iso' in share.""" """With required 'irmc_deploy_iso' in share."""
isfile_mock.return_value = True isfile_mock.return_value = True
self.node.driver_info['irmc_deploy_iso'] = 'deploy.iso' self.node.driver_info['irmc_deploy_iso'] = 'deploy.iso'
driver_info_expected = { driver_info_expected = {
'irmc_deploy_iso': 'deploy.iso', 'deploy_iso': 'deploy.iso',
'kernel_append_params': CONF.pxe.kernel_append_params, 'kernel_append_params': CONF.pxe.kernel_append_params,
} }
@ -125,10 +143,10 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
"""With overridden kernel_append_params.""" """With overridden kernel_append_params."""
isfile_mock.return_value = True isfile_mock.return_value = True
self.node.driver_info['irmc_deploy_iso'] = 'deploy.iso' self.node.driver_info['deploy_iso'] = 'deploy.iso'
self.node.instance_info['kernel_append_params'] = 'kernel params' self.node.instance_info['kernel_append_params'] = 'kernel params'
driver_info_expected = { driver_info_expected = {
'irmc_deploy_iso': 'deploy.iso', 'deploy_iso': 'deploy.iso',
'kernel_append_params': 'kernel params', 'kernel_append_params': 'kernel params',
} }
@ -145,9 +163,9 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
"""With overridden kernel_append_params.""" """With overridden kernel_append_params."""
self.config(kernel_append_params='kernel params', group='irmc') self.config(kernel_append_params='kernel params', group='irmc')
isfile_mock.return_value = True isfile_mock.return_value = True
self.node.driver_info['irmc_deploy_iso'] = 'deploy.iso' self.node.driver_info['deploy_iso'] = 'deploy.iso'
driver_info_expected = { driver_info_expected = {
'irmc_deploy_iso': 'deploy.iso', 'deploy_iso': 'deploy.iso',
'kernel_append_params': 'kernel params', 'kernel_append_params': 'kernel params',
} }
@ -163,10 +181,10 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
self, isfile_mock, check_share_fs_mounted_mock): self, isfile_mock, check_share_fs_mounted_mock):
"""With overridden kernel_append_params.""" """With overridden kernel_append_params."""
isfile_mock.return_value = True isfile_mock.return_value = True
self.node.driver_info['irmc_deploy_iso'] = 'deploy.iso' self.node.driver_info['deploy_iso'] = 'deploy.iso'
self.node.driver_info['kernel_append_params'] = 'kernel params' self.node.driver_info['kernel_append_params'] = 'kernel params'
driver_info_expected = { driver_info_expected = {
'irmc_deploy_iso': 'deploy.iso', 'deploy_iso': 'deploy.iso',
'kernel_append_params': 'kernel params', 'kernel_append_params': 'kernel params',
} }
@ -182,11 +200,11 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
def test__parse_driver_info_not_in_share( def test__parse_driver_info_not_in_share(
self, is_image_href_ordinary_file_name_mock, self, is_image_href_ordinary_file_name_mock,
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
"""With required 'irmc_deploy_iso' not in share.""" """With required 'rescue_iso' not in share."""
self.node.driver_info['irmc_rescue_iso'] = ( self.node.driver_info['rescue_iso'] = (
'bc784057-a140-4130-add3-ef890457e6b3') 'bc784057-a140-4130-add3-ef890457e6b3')
driver_info_expected = { driver_info_expected = {
'irmc_rescue_iso': 'bc784057-a140-4130-add3-ef890457e6b3', 'rescue_iso': 'bc784057-a140-4130-add3-ef890457e6b3',
'kernel_append_params': CONF.pxe.kernel_append_params 'kernel_append_params': CONF.pxe.kernel_append_params
} }
is_image_href_ordinary_file_name_mock.return_value = False is_image_href_ordinary_file_name_mock.return_value = False
@ -199,11 +217,11 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
@mock.patch.object(os.path, 'isfile', spec_set=True, autospec=True) @mock.patch.object(os.path, 'isfile', spec_set=True, autospec=True)
def test__parse_driver_info_with_iso_invalid(self, isfile_mock, def test__parse_driver_info_with_iso_invalid(self, isfile_mock,
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
"""With required 'irmc_deploy_iso' non existed.""" """With required 'deploy_iso' non existed."""
isfile_mock.return_value = False isfile_mock.return_value = False
with task_manager.acquire(self.context, self.node.uuid) as task: with task_manager.acquire(self.context, self.node.uuid) as task:
task.node.driver_info['irmc_deploy_iso'] = 'deploy.iso' task.node.driver_info['deploy_iso'] = 'deploy.iso'
error_msg = (_("Deploy ISO file, %(deploy_iso)s, " error_msg = (_("Deploy ISO file, %(deploy_iso)s, "
"not found for node: %(node)s.") % "not found for node: %(node)s.") %
{'deploy_iso': '/remote_image_share_root/deploy.iso', {'deploy_iso': '/remote_image_share_root/deploy.iso',
@ -216,12 +234,12 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
def test__parse_driver_info_with_iso_missing(self, def test__parse_driver_info_with_iso_missing(self,
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
"""With required 'irmc_rescue_iso' empty.""" """With required 'rescue_iso' empty."""
self.node.driver_info['irmc_rescue_iso'] = None self.node.driver_info['rescue_iso'] = None
error_msg = ("Error validating iRMC virtual media for rescue. Some" error_msg = ("Error validating iRMC virtual media for rescue. Some"
" parameters were missing in node's driver_info." " parameters were missing in node's driver_info."
" Missing are: ['irmc_rescue_iso']") " Missing are: ['rescue_iso']")
e = self.assertRaises(exception.MissingParameterValue, e = self.assertRaises(exception.MissingParameterValue,
irmc_boot._parse_driver_info, irmc_boot._parse_driver_info,
self.node, mode='rescue') self.node, mode='rescue')
@ -229,20 +247,30 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
def test__parse_instance_info_with_boot_iso_file_name_ok( def test__parse_instance_info_with_boot_iso_file_name_ok(
self, check_share_fs_mounted_mock): self, check_share_fs_mounted_mock):
"""With optional 'boot_iso' file name."""
CONF.irmc.remote_image_share_root = '/etc'
self.node.instance_info['boot_iso'] = 'hosts'
instance_info_expected = {'boot_iso': 'hosts'}
instance_info_actual = irmc_boot._parse_instance_info(self.node)
self.assertEqual(instance_info_expected, instance_info_actual)
def test__parse_instance_info_with_boot_iso_deprecated(
self, check_share_fs_mounted_mock):
"""With optional 'irmc_boot_iso' file name.""" """With optional 'irmc_boot_iso' file name."""
CONF.irmc.remote_image_share_root = '/etc' CONF.irmc.remote_image_share_root = '/etc'
self.node.instance_info['irmc_boot_iso'] = 'hosts' self.node.instance_info['irmc_boot_iso'] = 'hosts'
instance_info_expected = {'irmc_boot_iso': 'hosts'} instance_info_expected = {'boot_iso': 'hosts'}
instance_info_actual = irmc_boot._parse_instance_info(self.node) instance_info_actual = irmc_boot._parse_instance_info(self.node)
self.assertEqual(instance_info_expected, instance_info_actual) self.assertEqual(instance_info_expected, instance_info_actual)
def test__parse_instance_info_without_boot_iso_ok( def test__parse_instance_info_without_boot_iso_ok(
self, check_share_fs_mounted_mock): self, check_share_fs_mounted_mock):
"""With optional no 'irmc_boot_iso' file name.""" """With optional no 'boot_iso' file name."""
CONF.irmc.remote_image_share_root = '/etc' CONF.irmc.remote_image_share_root = '/etc'
self.node.instance_info['irmc_boot_iso'] = None self.node.instance_info['boot_iso'] = None
instance_info_expected = {} instance_info_expected = {}
instance_info_actual = irmc_boot._parse_instance_info(self.node) instance_info_actual = irmc_boot._parse_instance_info(self.node)
@ -250,10 +278,10 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
def test__parse_instance_info_with_boot_iso_uuid_ok( def test__parse_instance_info_with_boot_iso_uuid_ok(
self, check_share_fs_mounted_mock): self, check_share_fs_mounted_mock):
"""With optional 'irmc_boot_iso' glance uuid.""" """With optional 'boot_iso' glance uuid."""
self.node.instance_info[ self.node.instance_info[
'irmc_boot_iso'] = 'bc784057-a140-4130-add3-ef890457e6b3' 'boot_iso'] = 'bc784057-a140-4130-add3-ef890457e6b3'
instance_info_expected = {'irmc_boot_iso': instance_info_expected = {'boot_iso':
'bc784057-a140-4130-add3-ef890457e6b3'} 'bc784057-a140-4130-add3-ef890457e6b3'}
instance_info_actual = irmc_boot._parse_instance_info(self.node) instance_info_actual = irmc_boot._parse_instance_info(self.node)
@ -261,11 +289,11 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
def test__parse_instance_info_with_boot_iso_glance_ok( def test__parse_instance_info_with_boot_iso_glance_ok(
self, check_share_fs_mounted_mock): self, check_share_fs_mounted_mock):
"""With optional 'irmc_boot_iso' glance url.""" """With optional 'boot_iso' glance url."""
self.node.instance_info['irmc_boot_iso'] = ( self.node.instance_info['boot_iso'] = (
'glance://bc784057-a140-4130-add3-ef890457e6b3') 'glance://bc784057-a140-4130-add3-ef890457e6b3')
instance_info_expected = { instance_info_expected = {
'irmc_boot_iso': 'glance://bc784057-a140-4130-add3-ef890457e6b3', 'boot_iso': 'glance://bc784057-a140-4130-add3-ef890457e6b3',
} }
instance_info_actual = irmc_boot._parse_instance_info(self.node) instance_info_actual = irmc_boot._parse_instance_info(self.node)
@ -273,11 +301,11 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
def test__parse_instance_info_with_boot_iso_http_ok( def test__parse_instance_info_with_boot_iso_http_ok(
self, check_share_fs_mounted_mock): self, check_share_fs_mounted_mock):
"""With optional 'irmc_boot_iso' http url.""" """With optional 'boot_iso' http url."""
self.node.driver_info[ self.node.driver_info[
'irmc_deploy_iso'] = 'http://irmc_boot_iso' 'deploy_iso'] = 'http://irmc_boot_iso'
driver_info_expected = { driver_info_expected = {
'irmc_deploy_iso': 'http://irmc_boot_iso', 'deploy_iso': 'http://irmc_boot_iso',
'kernel_append_params': CONF.pxe.kernel_append_params 'kernel_append_params': CONF.pxe.kernel_append_params
} }
driver_info_actual = irmc_boot._parse_driver_info(self.node) driver_info_actual = irmc_boot._parse_driver_info(self.node)
@ -286,20 +314,20 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
def test__parse_instance_info_with_boot_iso_https_ok( def test__parse_instance_info_with_boot_iso_https_ok(
self, check_share_fs_mounted_mock): self, check_share_fs_mounted_mock):
"""With optional 'irmc_boot_iso' https url.""" """With optional 'boot_iso' https url."""
self.node.instance_info[ self.node.instance_info[
'irmc_boot_iso'] = 'https://irmc_boot_iso' 'boot_iso'] = 'https://irmc_boot_iso'
instance_info_expected = {'irmc_boot_iso': 'https://irmc_boot_iso'} instance_info_expected = {'boot_iso': 'https://irmc_boot_iso'}
instance_info_actual = irmc_boot._parse_instance_info(self.node) instance_info_actual = irmc_boot._parse_instance_info(self.node)
self.assertEqual(instance_info_expected, instance_info_actual) self.assertEqual(instance_info_expected, instance_info_actual)
def test__parse_instance_info_with_boot_iso_file_url_ok( def test__parse_instance_info_with_boot_iso_file_url_ok(
self, check_share_fs_mounted_mock): self, check_share_fs_mounted_mock):
"""With optional 'irmc_boot_iso' file url.""" """With optional 'boot_iso' file url."""
self.node.instance_info[ self.node.instance_info[
'irmc_boot_iso'] = 'file://irmc_boot_iso' 'boot_iso'] = 'file://irmc_boot_iso'
instance_info_expected = {'irmc_boot_iso': 'file://irmc_boot_iso'} instance_info_expected = {'boot_iso': 'file://irmc_boot_iso'}
instance_info_actual = irmc_boot._parse_instance_info(self.node) instance_info_actual = irmc_boot._parse_instance_info(self.node)
self.assertEqual(instance_info_expected, instance_info_actual) self.assertEqual(instance_info_expected, instance_info_actual)
@ -311,7 +339,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
isfile_mock.return_value = False isfile_mock.return_value = False
with task_manager.acquire(self.context, self.node.uuid) as task: with task_manager.acquire(self.context, self.node.uuid) as task:
task.node.instance_info['irmc_boot_iso'] = 'hosts~non~existed' task.node.instance_info['boot_iso'] = 'hosts~non~existed'
error_msg = (_("Boot ISO file, %(boot_iso)s, " error_msg = (_("Boot ISO file, %(boot_iso)s, "
"not found for node: %(node)s.") % "not found for node: %(node)s.") %
@ -333,19 +361,19 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
get_image_instance_info_mock.return_value = {'a': 'b'} get_image_instance_info_mock.return_value = {'a': 'b'}
driver_info_expected = { driver_info_expected = {
'a': 'b', 'a': 'b',
'irmc_deploy_iso': 'hosts', 'deploy_iso': 'hosts',
'irmc_boot_iso': 'fstab', 'boot_iso': 'fstab',
'kernel_append_params': CONF.pxe.kernel_append_params 'kernel_append_params': CONF.pxe.kernel_append_params
} }
with task_manager.acquire(self.context, self.node.uuid) as task: with task_manager.acquire(self.context, self.node.uuid) as task:
task.node.driver_info['irmc_deploy_iso'] = 'hosts' task.node.driver_info['deploy_iso'] = 'hosts'
task.node.instance_info['irmc_boot_iso'] = 'fstab' task.node.instance_info['boot_iso'] = 'fstab'
driver_info_actual = irmc_boot._parse_deploy_info(task.node) driver_info_actual = irmc_boot._parse_deploy_info(task.node)
self.assertEqual(driver_info_expected, driver_info_actual) self.assertEqual(driver_info_expected, driver_info_actual)
boot_iso_path = os.path.join( boot_iso_path = os.path.join(
CONF.irmc.remote_image_share_root, CONF.irmc.remote_image_share_root,
task.node.instance_info['irmc_boot_iso'] task.node.instance_info['boot_iso']
) )
mock_isfile.assert_any_call(boot_iso_path) mock_isfile.assert_any_call(boot_iso_path)
@ -362,7 +390,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task: shared=False) as task:
task.node.driver_info['irmc_deploy_iso'] = 'deploy_iso_filename' task.node.driver_info['deploy_iso'] = 'deploy_iso_filename'
ramdisk_opts = {'a': 'b'} ramdisk_opts = {'a': 'b'}
irmc_boot._setup_vmedia(task, mode='deploy', irmc_boot._setup_vmedia(task, mode='deploy',
ramdisk_options=ramdisk_opts) ramdisk_options=ramdisk_opts)
@ -389,7 +417,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task: shared=False) as task:
task.node.driver_info['irmc_rescue_iso'] = 'rescue_iso_filename' task.node.driver_info['rescue_iso'] = 'rescue_iso_filename'
ramdisk_opts = {'a': 'b'} ramdisk_opts = {'a': 'b'}
irmc_boot._setup_vmedia(task, mode='rescue', irmc_boot._setup_vmedia(task, mode='rescue',
ramdisk_options=ramdisk_opts) ramdisk_options=ramdisk_opts)
@ -419,7 +447,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task: shared=False) as task:
task.node.driver_info['irmc_deploy_iso'] = 'glance://deploy_iso' task.node.driver_info['deploy_iso'] = 'glance://deploy_iso'
ramdisk_opts = {'a': 'b'} ramdisk_opts = {'a': 'b'}
irmc_boot._setup_vmedia(task, mode='deploy', irmc_boot._setup_vmedia(task, mode='deploy',
ramdisk_options=ramdisk_opts) ramdisk_options=ramdisk_opts)
@ -452,7 +480,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task: shared=False) as task:
task.node.driver_info['irmc_rescue_iso'] = 'glance://rescue_iso' task.node.driver_info['rescue_iso'] = 'glance://rescue_iso'
ramdisk_opts = {'a': 'b'} ramdisk_opts = {'a': 'b'}
irmc_boot._setup_vmedia(task, mode='rescue', irmc_boot._setup_vmedia(task, mode='rescue',
ramdisk_options=ramdisk_opts) ramdisk_options=ramdisk_opts)
@ -490,7 +518,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
boot_mode_mock, boot_mode_mock,
create_boot_iso_mock, create_boot_iso_mock,
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
deploy_info_mock.return_value = {'irmc_boot_iso': 'irmc_boot.iso'} deploy_info_mock.return_value = {'boot_iso': 'irmc_boot.iso'}
with task_manager.acquire(self.context, self.node.uuid) as task: with task_manager.acquire(self.context, self.node.uuid) as task:
irmc_boot._prepare_boot_iso(task, 'root-uuid') irmc_boot._prepare_boot_iso(task, 'root-uuid')
@ -501,7 +529,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
self.assertFalse(create_boot_iso_mock.called) self.assertFalse(create_boot_iso_mock.called)
task.node.refresh() task.node.refresh()
self.assertEqual('irmc_boot.iso', self.assertEqual('irmc_boot.iso',
task.node.driver_internal_info['irmc_boot_iso']) task.node.driver_internal_info['boot_iso'])
@mock.patch.object(images, 'create_boot_iso', spec_set=True, autospec=True) @mock.patch.object(images, 'create_boot_iso', spec_set=True, autospec=True)
@mock.patch.object(boot_mode_utils, 'get_boot_mode_for_deploy', @mock.patch.object(boot_mode_utils, 'get_boot_mode_for_deploy',
@ -525,11 +553,11 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
CONF.irmc.remote_image_share_root = '/' CONF.irmc.remote_image_share_root = '/'
image = '733d1c44-a2ea-414b-aca7-69decf20d810' image = '733d1c44-a2ea-414b-aca7-69decf20d810'
is_image_href_ordinary_file_name_mock.return_value = False is_image_href_ordinary_file_name_mock.return_value = False
deploy_info_mock.return_value = {'irmc_boot_iso': image} deploy_info_mock.return_value = {'boot_iso': image}
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task: shared=False) as task:
task.node.instance_info['irmc_boot_iso'] = image task.node.instance_info['boot_iso'] = image
irmc_boot._prepare_boot_iso(task, 'root-uuid') irmc_boot._prepare_boot_iso(task, 'root-uuid')
deploy_info_mock.assert_called_once_with(task.node) deploy_info_mock.assert_called_once_with(task.node)
@ -542,7 +570,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
self.assertFalse(create_boot_iso_mock.called) self.assertFalse(create_boot_iso_mock.called)
task.node.refresh() task.node.refresh()
self.assertEqual("boot-%s.iso" % self.node.uuid, self.assertEqual("boot-%s.iso" % self.node.uuid,
task.node.driver_internal_info['irmc_boot_iso']) task.node.driver_internal_info['boot_iso'])
@mock.patch.object(images, 'create_boot_iso', spec_set=True, autospec=True) @mock.patch.object(images, 'create_boot_iso', spec_set=True, autospec=True)
@mock.patch.object(boot_mode_utils, 'get_boot_mode_for_deploy', @mock.patch.object(boot_mode_utils, 'get_boot_mode_for_deploy',
@ -562,7 +590,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
deploy_info_mock.return_value = \ deploy_info_mock.return_value = \
{'image_source': 'image-uuid', {'image_source': 'image-uuid',
'irmc_deploy_iso': '02f9d414-2ce0-4cf5-b48f-dbc1bf678f55', 'deploy_iso': '02f9d414-2ce0-4cf5-b48f-dbc1bf678f55',
'kernel_append_params': 'kernel-params'} 'kernel_append_params': 'kernel-params'}
image_props_mock.return_value = {'kernel_id': 'kernel_uuid', image_props_mock.return_value = {'kernel_id': 'kernel_uuid',
'ramdisk_id': 'ramdisk_uuid'} 'ramdisk_id': 'ramdisk_uuid'}
@ -587,7 +615,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
boot_mode='uefi') boot_mode='uefi')
task.node.refresh() task.node.refresh()
self.assertEqual("boot-%s.iso" % self.node.uuid, self.assertEqual("boot-%s.iso" % self.node.uuid,
task.node.driver_internal_info['irmc_boot_iso']) task.node.driver_internal_info['boot_iso'])
def test__get_floppy_image_name(self, check_share_fs_mounted_mock): def test__get_floppy_image_name(self, check_share_fs_mounted_mock):
actual = irmc_boot._get_floppy_image_name(self.node) actual = irmc_boot._get_floppy_image_name(self.node)
@ -663,6 +691,24 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
setup_vmedia_mock, setup_vmedia_mock,
set_boot_device_mock, set_boot_device_mock,
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
with task_manager.acquire(self.context, self.node.uuid,
shared=True) as task:
task.node.provision_state = states.ACTIVE
task.node.driver_internal_info['boot_iso'] = 'boot-iso'
irmc_boot.attach_boot_iso_if_needed(task)
setup_vmedia_mock.assert_called_once_with(task, 'boot-iso')
set_boot_device_mock.assert_called_once_with(
task, boot_devices.CDROM)
@mock.patch.object(manager_utils, 'node_set_boot_device', spec_set=True,
autospec=True)
@mock.patch.object(irmc_boot, '_setup_vmedia_for_boot', spec_set=True,
autospec=True)
def test_attach_boot_iso_if_needed_deprecated(
self,
setup_vmedia_mock,
set_boot_device_mock,
check_share_fs_mounted_mock):
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=True) as task: shared=True) as task:
task.node.provision_state = states.ACTIVE task.node.provision_state = states.ACTIVE
@ -684,7 +730,7 @@ class IRMCDeployPrivateMethodsTestCase(test_common.BaseIRMCTest):
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=True) as task: shared=True) as task:
task.node.provision_state = states.DEPLOYING task.node.provision_state = states.DEPLOYING
task.node.driver_internal_info['irmc_boot_iso'] = 'boot-iso' task.node.driver_internal_info['boot_iso'] = 'boot-iso'
irmc_boot.attach_boot_iso_if_needed(task) irmc_boot.attach_boot_iso_if_needed(task)
self.assertFalse(setup_vmedia_mock.called) self.assertFalse(setup_vmedia_mock.called)
self.assertFalse(set_boot_device_mock.called) self.assertFalse(set_boot_device_mock.called)
@ -1078,7 +1124,7 @@ class IRMCVirtualMediaBootTestCase(test_common.BaseIRMCTest):
mock_backup_bios, mock_backup_bios,
mode='deploy'): mode='deploy'):
instance_info = self.node.instance_info instance_info = self.node.instance_info
instance_info['irmc_boot_iso'] = 'glance://abcdef' instance_info['boot_iso'] = 'glance://abcdef'
instance_info['image_source'] = '6b2f0c0c-79e8-4db6-842e-43c9764204af' instance_info['image_source'] = '6b2f0c0c-79e8-4db6-842e-43c9764204af'
self.node.instance_info = instance_info self.node.instance_info = instance_info
self.node.save() self.node.save()
@ -1097,7 +1143,7 @@ class IRMCVirtualMediaBootTestCase(test_common.BaseIRMCTest):
_setup_vmedia_mock.assert_called_once_with( _setup_vmedia_mock.assert_called_once_with(
task, mode, expected_ramdisk_opts) task, mode, expected_ramdisk_opts)
self.assertEqual('glance://abcdef', self.assertEqual('glance://abcdef',
self.node.instance_info['irmc_boot_iso']) self.node.instance_info['boot_iso'])
provision_state = task.node.provision_state provision_state = task.node.provision_state
self.assertEqual(1 if provision_state == states.DEPLOYING else 0, self.assertEqual(1 if provision_state == states.DEPLOYING else 0,
mock_backup_bios.call_count) mock_backup_bios.call_count)
@ -1201,15 +1247,14 @@ class IRMCVirtualMediaBootTestCase(test_common.BaseIRMCTest):
check_share_fs_mounted_mock): check_share_fs_mounted_mock):
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task: shared=False) as task:
task.node.instance_info['irmc_boot_iso'] = 'glance://deploy_iso' task.node.instance_info['boot_iso'] = 'glance://deploy_iso'
task.node.driver_internal_info['irmc_boot_iso'] = 'irmc_boot.iso' task.node.driver_internal_info['boot_iso'] = 'irmc_boot.iso'
task.driver.boot.clean_up_instance(task) task.driver.boot.clean_up_instance(task)
_remove_share_file_mock.assert_called_once_with( _remove_share_file_mock.assert_called_once_with(
irmc_boot._get_iso_name(task.node, label='boot')) irmc_boot._get_iso_name(task.node, label='boot'))
self.assertNotIn('irmc_boot_iso', self.assertNotIn('boot_iso', task.node.driver_internal_info)
task.node.driver_internal_info)
_cleanup_vmedia_boot_mock.assert_called_once_with(task) _cleanup_vmedia_boot_mock.assert_called_once_with(task)
@mock.patch.object(manager_utils, 'node_set_boot_device', spec_set=True, @mock.patch.object(manager_utils, 'node_set_boot_device', spec_set=True,
@ -1227,7 +1272,7 @@ class IRMCVirtualMediaBootTestCase(test_common.BaseIRMCTest):
with task_manager.acquire(self.context, self.node.uuid, with task_manager.acquire(self.context, self.node.uuid,
shared=False) as task: shared=False) as task:
task.node.driver_internal_info['irmc_boot_iso'] = 'boot.iso' task.node.driver_internal_info['boot_iso'] = 'boot.iso'
task.driver.boot._configure_vmedia_boot( task.driver.boot._configure_vmedia_boot(
task, root_uuid_or_disk_id) task, root_uuid_or_disk_id)
@ -1391,7 +1436,7 @@ class IRMCVirtualMediaBootTestCase(test_common.BaseIRMCTest):
autospec=True) autospec=True)
def test_validate_rescue(self, mock_isfile, check_share_fs_mounted_mock): def test_validate_rescue(self, mock_isfile, check_share_fs_mounted_mock):
driver_info = self.node.driver_info driver_info = self.node.driver_info
driver_info['irmc_rescue_iso'] = 'rescue.iso' driver_info['rescue_iso'] = 'rescue.iso'
self.node.driver_info = driver_info self.node.driver_info = driver_info
self.node.save() self.node.save()
with task_manager.acquire(self.context, self.node.uuid) as task: with task_manager.acquire(self.context, self.node.uuid) as task:
@ -1401,7 +1446,7 @@ class IRMCVirtualMediaBootTestCase(test_common.BaseIRMCTest):
self, check_share_fs_mounted_mock): self, check_share_fs_mounted_mock):
with task_manager.acquire(self.context, self.node.uuid) as task: with task_manager.acquire(self.context, self.node.uuid) as task:
self.assertRaisesRegex(exception.MissingParameterValue, self.assertRaisesRegex(exception.MissingParameterValue,
'Missing.*irmc_rescue_iso', 'Missing.*rescue_iso',
task.driver.boot.validate_rescue, task) task.driver.boot.validate_rescue, task)
@mock.patch.object(os.path, 'isfile', return_value=False, @mock.patch.object(os.path, 'isfile', return_value=False,
@ -1409,7 +1454,7 @@ class IRMCVirtualMediaBootTestCase(test_common.BaseIRMCTest):
def test_validate_rescue_ramdisk_not_exist( def test_validate_rescue_ramdisk_not_exist(
self, mock_isfile, check_share_fs_mounted_mock): self, mock_isfile, check_share_fs_mounted_mock):
driver_info = self.node.driver_info driver_info = self.node.driver_info
driver_info['irmc_rescue_iso'] = 'rescue.iso' driver_info['rescue_iso'] = 'rescue.iso'
self.node.driver_info = driver_info self.node.driver_info = driver_info
self.node.save() self.node.save()
with task_manager.acquire(self.context, self.node.uuid) as task: with task_manager.acquire(self.context, self.node.uuid) as task:

View File

@ -0,0 +1,8 @@
---
deprecations:
- |
The ``driver_info`` properties ``irmc_deploy_iso`` and ``irmc_rescue_iso``
have been renamed to just ``deploy_iso`` and ``rescue_iso``.
- |
The ``instance_info`` property ``irmc_boot_iso`` has been renamed to just
``boot_iso``.