Fix Redfish RAID to update raid_config
Story: 2003514 Task: 41940 Change-Id: I753c4b00c0a64bcdc89c9bc0afd46f1211f7847b
This commit is contained in:
parent
bcd81c0b28
commit
29364b7fb4
@ -23,6 +23,7 @@ from oslo_utils import units
|
|||||||
|
|
||||||
from ironic.common import exception
|
from ironic.common import exception
|
||||||
from ironic.common.i18n import _
|
from ironic.common.i18n import _
|
||||||
|
from ironic.common import raid as raid_common
|
||||||
from ironic.common import raid
|
from ironic.common import raid
|
||||||
from ironic.common import states
|
from ironic.common import states
|
||||||
from ironic.conductor import periodics
|
from ironic.conductor import periodics
|
||||||
@ -685,6 +686,30 @@ def create_virtual_disk(task, raid_controller, physical_disks, raid_level,
|
|||||||
raise exception.RedfishError(error=exc)
|
raise exception.RedfishError(error=exc)
|
||||||
|
|
||||||
|
|
||||||
|
def update_raid_config(node):
|
||||||
|
"""Updates node's raid_config field with current logical disks.
|
||||||
|
|
||||||
|
:param node: node for which to update the raid_config field
|
||||||
|
"""
|
||||||
|
system = redfish_utils.get_system(node)
|
||||||
|
logical_disks = []
|
||||||
|
for stor in system.storage.get_members():
|
||||||
|
for vol in stor.volumes.get_members():
|
||||||
|
if vol.raid_type:
|
||||||
|
logical_disk = {
|
||||||
|
'id': vol.identity,
|
||||||
|
'name': vol.name,
|
||||||
|
'controller': stor.identity,
|
||||||
|
'size_gb': int(vol.capacity_bytes / units.Gi),
|
||||||
|
'raid_level': next(
|
||||||
|
key for key, value in RAID_LEVELS.items()
|
||||||
|
if value['raid_type'] == vol.raid_type.value)
|
||||||
|
}
|
||||||
|
logical_disks.append(logical_disk)
|
||||||
|
|
||||||
|
raid_common.update_raid_info(node, {'logical_disks': logical_disks})
|
||||||
|
|
||||||
|
|
||||||
class RedfishRAID(base.RAIDInterface):
|
class RedfishRAID(base.RAIDInterface):
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
@ -809,6 +834,8 @@ class RedfishRAID(base.RAIDInterface):
|
|||||||
polling=True)
|
polling=True)
|
||||||
if reboot_required:
|
if reboot_required:
|
||||||
return_state = deploy_utils.reboot_to_finish_step(task)
|
return_state = deploy_utils.reboot_to_finish_step(task)
|
||||||
|
else:
|
||||||
|
update_raid_config(node)
|
||||||
|
|
||||||
return self.post_create_configuration(
|
return self.post_create_configuration(
|
||||||
task, raid_configs, return_state=return_state)
|
task, raid_configs, return_state=return_state)
|
||||||
@ -835,6 +862,8 @@ class RedfishRAID(base.RAIDInterface):
|
|||||||
polling=True)
|
polling=True)
|
||||||
if reboot_required:
|
if reboot_required:
|
||||||
return_state = deploy_utils.reboot_to_finish_step(task)
|
return_state = deploy_utils.reboot_to_finish_step(task)
|
||||||
|
else:
|
||||||
|
update_raid_config(node)
|
||||||
|
|
||||||
return self.post_delete_configuration(
|
return self.post_delete_configuration(
|
||||||
task, raid_configs, return_state=return_state)
|
task, raid_configs, return_state=return_state)
|
||||||
@ -940,6 +969,7 @@ class RedfishRAID(base.RAIDInterface):
|
|||||||
|
|
||||||
task.upgrade_lock()
|
task.upgrade_lock()
|
||||||
self._clear_raid_configs(task.node)
|
self._clear_raid_configs(task.node)
|
||||||
|
update_raid_config(task.node)
|
||||||
|
|
||||||
@METRICS.timer('RedfishRAID._query_raid_config_status')
|
@METRICS.timer('RedfishRAID._query_raid_config_status')
|
||||||
@periodics.node_periodic(
|
@periodics.node_periodic(
|
||||||
@ -1036,6 +1066,7 @@ class RedfishRAID(base.RAIDInterface):
|
|||||||
self._clear_raid_configs(node)
|
self._clear_raid_configs(node)
|
||||||
LOG.info('RAID configuration completed for node %(node)s',
|
LOG.info('RAID configuration completed for node %(node)s',
|
||||||
{'node': node.uuid})
|
{'node': node.uuid})
|
||||||
|
update_raid_config(task.node)
|
||||||
if task.node.clean_step:
|
if task.node.clean_step:
|
||||||
manager_utils.notify_conductor_resume_clean(task)
|
manager_utils.notify_conductor_resume_clean(task)
|
||||||
else:
|
else:
|
||||||
|
@ -47,13 +47,16 @@ def _mock_drive(identity, block_size_bytes=None, capacity_bytes=None,
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def _mock_volume(identity, volume_type=None, raid_type=None):
|
def _mock_volume(identity, volume_type=None, raid_type=None,
|
||||||
|
capacity_bytes=units.Gi):
|
||||||
volume = mock.MagicMock(
|
volume = mock.MagicMock(
|
||||||
_path='/redfish/v1/Systems/1/Storage/1/Volumes/' + identity,
|
_path='/redfish/v1/Systems/1/Storage/1/Volumes/' + identity,
|
||||||
identity=identity,
|
identity=identity,
|
||||||
volume_type=volume_type,
|
volume_type=volume_type,
|
||||||
raid_type=raid_type
|
raid_type=raid_type,
|
||||||
|
capacity_bytes=capacity_bytes
|
||||||
)
|
)
|
||||||
|
volume.name = 'Volume ' + identity
|
||||||
# Mocking Immediate that does not return anything
|
# Mocking Immediate that does not return anything
|
||||||
volume.delete.return_value = None
|
volume.delete.return_value = None
|
||||||
return volume
|
return volume
|
||||||
@ -263,6 +266,8 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
self.mock_storage.volumes.create.assert_called_once_with(
|
self.mock_storage.volumes.create.assert_called_once_with(
|
||||||
expected_payload, apply_time=None
|
expected_payload, apply_time=None
|
||||||
)
|
)
|
||||||
|
# Async operation, raid_config shouldn't be updated yet
|
||||||
|
self.assertEqual({}, task.node.raid_config)
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -288,7 +293,12 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
created_volumes = [_mock_volume(
|
||||||
|
'1', raid_type=sushy.RAIDType.RAID5,
|
||||||
|
capacity_bytes=100 * units.Gi)]
|
||||||
volumes = mock.MagicMock()
|
volumes = mock.MagicMock()
|
||||||
|
# Called after volumes created
|
||||||
|
volumes.get_members.return_value = created_volumes
|
||||||
op_apply_time_support = mock.MagicMock()
|
op_apply_time_support = mock.MagicMock()
|
||||||
op_apply_time_support.mapped_supported_values = [
|
op_apply_time_support.mapped_supported_values = [
|
||||||
sushy.APPLY_TIME_IMMEDIATE, sushy.APPLY_TIME_ON_RESET]
|
sushy.APPLY_TIME_IMMEDIATE, sushy.APPLY_TIME_ON_RESET]
|
||||||
@ -326,6 +336,13 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
self.assertEqual(mock_node_power_action.call_count, 0)
|
self.assertEqual(mock_node_power_action.call_count, 0)
|
||||||
self.assertEqual(mock_build_agent_options.call_count, 0)
|
self.assertEqual(mock_build_agent_options.call_count, 0)
|
||||||
self.assertEqual(mock_prepare_ramdisk.call_count, 0)
|
self.assertEqual(mock_prepare_ramdisk.call_count, 0)
|
||||||
|
self.assertEqual(
|
||||||
|
[{'controller': 'RAID controller 1',
|
||||||
|
'id': '1',
|
||||||
|
'name': 'Volume 1',
|
||||||
|
'raid_level': '5',
|
||||||
|
'size_gb': 100}],
|
||||||
|
task.node.raid_config['logical_disks'])
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -390,6 +407,8 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
mock_node_power_action.assert_called_once_with(task, states.REBOOT)
|
mock_node_power_action.assert_called_once_with(task, states.REBOOT)
|
||||||
mock_build_agent_options.assert_called_once_with(task.node)
|
mock_build_agent_options.assert_called_once_with(task.node)
|
||||||
self.assertEqual(mock_prepare_ramdisk.call_count, 1)
|
self.assertEqual(mock_prepare_ramdisk.call_count, 1)
|
||||||
|
# Async operation, raid_config shouldn't be updated yet
|
||||||
|
self.assertEqual({}, task.node.raid_config)
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -422,9 +441,16 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
created_volumes = [
|
||||||
|
_mock_volume('1', raid_type=sushy.RAIDType.RAID5,
|
||||||
|
capacity_bytes=100 * units.Gi),
|
||||||
|
_mock_volume('2', raid_type=sushy.RAIDType.RAID1,
|
||||||
|
capacity_bytes=500 * units.Gi)]
|
||||||
resource = mock.MagicMock(spec=['resource_name'])
|
resource = mock.MagicMock(spec=['resource_name'])
|
||||||
resource.resource_name = 'volume'
|
resource.resource_name = 'volume'
|
||||||
self.mock_storage.volumes.create.return_value = resource
|
self.mock_storage.volumes.create.return_value = resource
|
||||||
|
# Called after volumes created
|
||||||
|
self.mock_storage.volumes.get_members.return_value = created_volumes
|
||||||
mock_get_system.return_value.storage.get_members.return_value = [
|
mock_get_system.return_value.storage.get_members.return_value = [
|
||||||
self.mock_storage]
|
self.mock_storage]
|
||||||
self.node.target_raid_config = target_raid_config
|
self.node.target_raid_config = target_raid_config
|
||||||
@ -466,6 +492,18 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
self.mock_storage.volumes.create.assert_any_call(
|
self.mock_storage.volumes.create.assert_any_call(
|
||||||
expected_payload2, apply_time=None
|
expected_payload2, apply_time=None
|
||||||
)
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
[{'controller': 'RAID controller 1',
|
||||||
|
'id': '1',
|
||||||
|
'name': 'Volume 1',
|
||||||
|
'raid_level': '5',
|
||||||
|
'size_gb': 100},
|
||||||
|
{'controller': 'RAID controller 1',
|
||||||
|
'id': '2',
|
||||||
|
'name': 'Volume 2',
|
||||||
|
'raid_level': '1',
|
||||||
|
'size_gb': 500}],
|
||||||
|
task.node.raid_config['logical_disks'])
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -548,6 +586,8 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
expected_raid_configs,
|
expected_raid_configs,
|
||||||
task.node.driver_internal_info.get('raid_configs'))
|
task.node.driver_internal_info.get('raid_configs'))
|
||||||
|
# Async operation, raid_config shouldn't be updated yet
|
||||||
|
self.assertEqual({}, task.node.raid_config)
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -604,6 +644,8 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
self.mock_storage.volumes.create.assert_called_once_with(
|
self.mock_storage.volumes.create.assert_called_once_with(
|
||||||
expected_payload, apply_time=None
|
expected_payload, apply_time=None
|
||||||
)
|
)
|
||||||
|
# Async operation, raid_config shouldn't be updated yet
|
||||||
|
self.assertEqual({}, task.node.raid_config)
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -662,6 +704,15 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
resource = mock.MagicMock(spec=['resource_name'])
|
resource = mock.MagicMock(spec=['resource_name'])
|
||||||
resource.resource_name = 'volume'
|
resource.resource_name = 'volume'
|
||||||
self.mock_storage.volumes.create.return_value = resource
|
self.mock_storage.volumes.create.return_value = resource
|
||||||
|
created_volumes = [
|
||||||
|
_mock_volume(
|
||||||
|
'1', raid_type=sushy.RAIDType.RAID10,
|
||||||
|
capacity_bytes=50 * units.Gi),
|
||||||
|
_mock_volume(
|
||||||
|
'2', raid_type=sushy.RAIDType.RAID5,
|
||||||
|
capacity_bytes=100 * units.Gi)]
|
||||||
|
# Called after volumes created
|
||||||
|
self.mock_storage.volumes.get_members.return_value = created_volumes
|
||||||
mock_get_system.return_value.storage.get_members.return_value = [
|
mock_get_system.return_value.storage.get_members.return_value = [
|
||||||
self.mock_storage]
|
self.mock_storage]
|
||||||
self.node.target_raid_config = target_raid_config
|
self.node.target_raid_config = target_raid_config
|
||||||
@ -705,6 +756,19 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
self.mock_storage.volumes.create.assert_any_call(
|
self.mock_storage.volumes.create.assert_any_call(
|
||||||
expected_payload2, apply_time=None
|
expected_payload2, apply_time=None
|
||||||
)
|
)
|
||||||
|
# Async operation, raid_config shouldn't be updated yet
|
||||||
|
self.assertEqual(
|
||||||
|
[{'controller': 'RAID controller 1',
|
||||||
|
'id': '1',
|
||||||
|
'name': 'Volume 1',
|
||||||
|
'raid_level': '1+0',
|
||||||
|
'size_gb': 50},
|
||||||
|
{'controller': 'RAID controller 1',
|
||||||
|
'id': '2',
|
||||||
|
'name': 'Volume 2',
|
||||||
|
'raid_level': '5',
|
||||||
|
'size_gb': 100}],
|
||||||
|
task.node.raid_config['logical_disks'])
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -891,6 +955,15 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
resource = mock.MagicMock(spec=['resource_name'])
|
resource = mock.MagicMock(spec=['resource_name'])
|
||||||
resource.resource_name = 'volume'
|
resource.resource_name = 'volume'
|
||||||
self.mock_storage.volumes.create.return_value = resource
|
self.mock_storage.volumes.create.return_value = resource
|
||||||
|
created_volumes = [
|
||||||
|
_mock_volume(
|
||||||
|
'1', raid_type=sushy.RAIDType.RAID5,
|
||||||
|
capacity_bytes=100 * units.Gi),
|
||||||
|
_mock_volume(
|
||||||
|
'2', raid_type=sushy.RAIDType.RAID1,
|
||||||
|
capacity_bytes=500 * units.Gi)]
|
||||||
|
# Called after volumes created
|
||||||
|
self.mock_storage.volumes.get_members.return_value = created_volumes
|
||||||
mock_get_system.return_value.storage.get_members.return_value = [
|
mock_get_system.return_value.storage.get_members.return_value = [
|
||||||
self.mock_storage]
|
self.mock_storage]
|
||||||
self.node.target_raid_config = target_raid_config
|
self.node.target_raid_config = target_raid_config
|
||||||
@ -932,6 +1005,18 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
self.mock_storage.volumes.create.assert_any_call(
|
self.mock_storage.volumes.create.assert_any_call(
|
||||||
expected_payload2, apply_time=None
|
expected_payload2, apply_time=None
|
||||||
)
|
)
|
||||||
|
self.assertEqual(
|
||||||
|
[{'controller': 'RAID controller 1',
|
||||||
|
'id': '1',
|
||||||
|
'name': 'Volume 1',
|
||||||
|
'raid_level': '5',
|
||||||
|
'size_gb': 100},
|
||||||
|
{'controller': 'RAID controller 1',
|
||||||
|
'id': '2',
|
||||||
|
'name': 'Volume 2',
|
||||||
|
'raid_level': '1',
|
||||||
|
'size_gb': 500}],
|
||||||
|
task.node.raid_config['logical_disks'])
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -951,17 +1036,27 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
mock_volumes = []
|
mock_volumes = []
|
||||||
for i in ["1", "2"]:
|
for i in ["1", "2"]:
|
||||||
mock_volumes.append(_mock_volume(
|
mock_volumes.append(_mock_volume(
|
||||||
i, volume_type='Mirrored', raid_type='RAID1'))
|
i, volume_type='Mirrored', raid_type=sushy.RAIDType.RAID1))
|
||||||
op_apply_time_support = mock.MagicMock()
|
op_apply_time_support = mock.MagicMock()
|
||||||
op_apply_time_support.mapped_supported_values = [
|
op_apply_time_support.mapped_supported_values = [
|
||||||
sushy.APPLY_TIME_IMMEDIATE, sushy.APPLY_TIME_ON_RESET]
|
sushy.APPLY_TIME_IMMEDIATE, sushy.APPLY_TIME_ON_RESET]
|
||||||
self.mock_storage.volumes.operation_apply_time_support = (
|
self.mock_storage.volumes.operation_apply_time_support = (
|
||||||
op_apply_time_support)
|
op_apply_time_support)
|
||||||
self.mock_storage.volumes.get_members.return_value = mock_volumes
|
# 2nd call to mock no volumes after delete
|
||||||
|
self.mock_storage.volumes.get_members.side_effect = [mock_volumes, []]
|
||||||
mock_get_system.return_value.storage.get_members.return_value = [
|
mock_get_system.return_value.storage.get_members.return_value = [
|
||||||
self.mock_storage]
|
self.mock_storage]
|
||||||
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:
|
||||||
|
last_updated = '2022-05-18 08:49:17.585443'
|
||||||
|
task.node.raid_config = {
|
||||||
|
'logical_disks': [{
|
||||||
|
'controller': 'RAID controller 1',
|
||||||
|
'id': '1',
|
||||||
|
'name': 'Volume 1',
|
||||||
|
'raid_level': '1',
|
||||||
|
'size_gb': 100}],
|
||||||
|
'last_updated': last_updated}
|
||||||
task.driver.raid.delete_configuration(task)
|
task.driver.raid.delete_configuration(task)
|
||||||
self.assertEqual(mock_volumes[0].delete.call_count, 1)
|
self.assertEqual(mock_volumes[0].delete.call_count, 1)
|
||||||
self.assertEqual(mock_volumes[1].delete.call_count, 1)
|
self.assertEqual(mock_volumes[1].delete.call_count, 1)
|
||||||
@ -971,6 +1066,9 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
self.assertEqual(mock_node_power_action.call_count, 0)
|
self.assertEqual(mock_node_power_action.call_count, 0)
|
||||||
self.assertEqual(mock_build_agent_options.call_count, 0)
|
self.assertEqual(mock_build_agent_options.call_count, 0)
|
||||||
self.assertEqual(mock_prepare_ramdisk.call_count, 0)
|
self.assertEqual(mock_prepare_ramdisk.call_count, 0)
|
||||||
|
self.assertEqual([], task.node.raid_config['logical_disks'])
|
||||||
|
self.assertNotEqual(
|
||||||
|
last_updated, task.node.raid_config['last_updated'])
|
||||||
|
|
||||||
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
@mock.patch.object(redfish_boot.RedfishVirtualMediaBoot, 'prepare_ramdisk',
|
||||||
spec_set=True, autospec=True)
|
spec_set=True, autospec=True)
|
||||||
@ -990,7 +1088,7 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
mock_volumes = []
|
mock_volumes = []
|
||||||
for i in ["1", "2"]:
|
for i in ["1", "2"]:
|
||||||
mock_volumes.append(_mock_volume(
|
mock_volumes.append(_mock_volume(
|
||||||
i, volume_type='Mirrored', raid_type='RAID1'))
|
i, volume_type='Mirrored', raid_type=sushy.RAIDType.RAID1))
|
||||||
op_apply_time_support = mock.MagicMock()
|
op_apply_time_support = mock.MagicMock()
|
||||||
op_apply_time_support.mapped_supported_values = [
|
op_apply_time_support.mapped_supported_values = [
|
||||||
sushy.APPLY_TIME_ON_RESET]
|
sushy.APPLY_TIME_ON_RESET]
|
||||||
@ -1005,6 +1103,15 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
mock_volumes[1].delete.return_value = task_mon
|
mock_volumes[1].delete.return_value = task_mon
|
||||||
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:
|
||||||
|
raid_config = {
|
||||||
|
'logical_disks': [{
|
||||||
|
'controller': 'RAID controller 1',
|
||||||
|
'id': '1',
|
||||||
|
'name': 'Volume 1',
|
||||||
|
'raid_level': '1',
|
||||||
|
'size_gb': 100}],
|
||||||
|
'last_updated': '2022-05-18 08:49:17.585443'}
|
||||||
|
task.node.raid_config = raid_config
|
||||||
task.driver.raid.delete_configuration(task)
|
task.driver.raid.delete_configuration(task)
|
||||||
self.assertEqual(mock_volumes[0].delete.call_count, 1)
|
self.assertEqual(mock_volumes[0].delete.call_count, 1)
|
||||||
self.assertEqual(mock_volumes[1].delete.call_count, 0)
|
self.assertEqual(mock_volumes[1].delete.call_count, 0)
|
||||||
@ -1020,6 +1127,8 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
'pending': True,
|
'pending': True,
|
||||||
'task_monitor_uri': ['/TaskService/123']},
|
'task_monitor_uri': ['/TaskService/123']},
|
||||||
task.node.driver_internal_info.get('raid_configs'))
|
task.node.driver_internal_info.get('raid_configs'))
|
||||||
|
# Async operation, raid_config shouldn't be updated yet
|
||||||
|
self.assertEqual(raid_config, task.node.raid_config)
|
||||||
|
|
||||||
def test_volume_create_error_handler(self, mock_get_system):
|
def test_volume_create_error_handler(self, mock_get_system):
|
||||||
volume_collection = self.mock_storage.volumes
|
volume_collection = self.mock_storage.volumes
|
||||||
@ -1251,6 +1360,8 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
|
|
||||||
mock_resume_deploy.assert_called_with(task)
|
mock_resume_deploy.assert_called_with(task)
|
||||||
mock_resume_clean.assert_not_called()
|
mock_resume_clean.assert_not_called()
|
||||||
|
self.assertEqual([], task.node.raid_config['logical_disks'])
|
||||||
|
self.assertIsNotNone(task.node.raid_config.get('last_updated'))
|
||||||
|
|
||||||
@mock.patch.object(manager_utils, 'notify_conductor_resume_clean',
|
@mock.patch.object(manager_utils, 'notify_conductor_resume_clean',
|
||||||
autospec=True)
|
autospec=True)
|
||||||
@ -1281,6 +1392,8 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
|
|
||||||
mock_resume_deploy.assert_not_called()
|
mock_resume_deploy.assert_not_called()
|
||||||
mock_resume_clean.assert_called_with(task)
|
mock_resume_clean.assert_called_with(task)
|
||||||
|
self.assertEqual([], task.node.raid_config['logical_disks'])
|
||||||
|
self.assertIsNotNone(task.node.raid_config.get('last_updated'))
|
||||||
|
|
||||||
@mock.patch.object(redfish_utils, 'get_task_monitor',
|
@mock.patch.object(redfish_utils, 'get_task_monitor',
|
||||||
autospec=True)
|
autospec=True)
|
||||||
@ -1329,6 +1442,8 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
raid, task, raid_configs['pending'])
|
raid, task, raid_configs['pending'])
|
||||||
mock_submit_delete.assert_not_called()
|
mock_submit_delete.assert_not_called()
|
||||||
mock_reboot.assert_called_with(task)
|
mock_reboot.assert_called_with(task)
|
||||||
|
# Not yet updated as in progress
|
||||||
|
self.assertEqual({}, task.node.raid_config)
|
||||||
|
|
||||||
@mock.patch.object(redfish_utils, 'get_task_monitor',
|
@mock.patch.object(redfish_utils, 'get_task_monitor',
|
||||||
autospec=True)
|
autospec=True)
|
||||||
@ -1366,3 +1481,5 @@ class RedfishRAIDTestCase(db_base.DbTestCase):
|
|||||||
mock_submit_create.assert_not_called()
|
mock_submit_create.assert_not_called()
|
||||||
mock_submit_delete.assert_called_with(raid, task)
|
mock_submit_delete.assert_called_with(raid, task)
|
||||||
mock_reboot.assert_not_called()
|
mock_reboot.assert_not_called()
|
||||||
|
# Not yet updated as in progress
|
||||||
|
self.assertEqual({}, task.node.raid_config)
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
Fixes ``redfish`` and ``idrac-redfish`` RAID ``create_configuration``,
|
||||||
|
``apply_configuration``, ``delete_configuration`` clean and deploy steps to
|
||||||
|
update node's ``raid_config`` field at the end of the steps.
|
Loading…
x
Reference in New Issue
Block a user