Merge "Clean up vendor prefixes for iRMC boot"
This commit is contained in:
commit
e16513f9fe
@ -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
|
||||||
|
@ -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``:
|
||||||
|
|
||||||
|
@ -58,12 +58,11 @@ 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.")
|
||||||
}
|
}
|
||||||
@ -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)
|
||||||
|
|
||||||
|
@ -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:
|
||||||
|
8
releasenotes/notes/irmc-boot-iso-0e93f97acfa59778.yaml
Normal file
8
releasenotes/notes/irmc-boot-iso-0e93f97acfa59778.yaml
Normal 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``.
|
Loading…
Reference in New Issue
Block a user