[SVF] Update rccg details for mirror volumes

[Spectrum Virtualize Family] For a volume with replication enabled,
during volume creation, _update_replication_properties are fetching
relationship details and updating to metadata except for rccg
properties as that volume is not added to a group. Updating IBM
Storwize cinder driver to update rccg details of a volume to metadata
when it is added to a group or removed from a group.

Closes-Bug: #1926491

Change-Id: Id3f316d58c3aa7d7930ad8d1cbb96409a39e1ba9
This commit is contained in:
venkatakrishnathumu 2021-04-29 13:59:01 +00:00 committed by Venkata Krishna
parent 81aaa5da12
commit a6488ba877
3 changed files with 114 additions and 45 deletions

View File

@ -12235,10 +12235,14 @@ class StorwizeSVCReplicationTestCase(test.TestCase):
group = self._create_test_rccg(self.rccg_type, [self.mm_type.id])
mm_vol, model_update = self._create_test_volume(self.mm_type)
gm_vol, model_update = self._create_test_volume(self.gm_type)
with mock.patch.object(storwize_svc_common.StorwizeSVCCommonDriver,
'_update_rccg_properties') as update_rccg_prop:
add_vols = [mm_vol, gm_vol]
(model_update, add_volumes_update,
remove_volumes_update) = self.driver.update_group(
self.ctxt, group, add_vols, [])
update_rccg_prop.assert_called()
self.assertEqual(1, update_rccg_prop.call_count)
self.assertEqual(fields.GroupStatus.ERROR, model_update['status'])
self.assertEqual([{'id': mm_vol.id, 'group_id': group.id}],
add_volumes_update)
@ -12261,17 +12265,22 @@ class StorwizeSVCReplicationTestCase(test.TestCase):
rcrel = self.driver._helpers.get_relationship_info(mm_vol4.name)
self.sim._rc_state_transition('wait', rcrel)
with mock.patch.object(storwize_svc_common.StorwizeSVCCommonDriver,
'_update_rccg_properties') as update_rccg_prop:
add_vols = [mm_vol1, mm_vol2]
(model_update, add_volumes_update,
remove_volumes_update) = self.driver.update_group(
self.ctxt, group, add_vols, [])
update_rccg_prop.assert_called()
self.assertEqual(2, update_rccg_prop.call_count)
self.assertEqual(
rccg_name,
self.driver._helpers.get_rccg_info(mm_vol1.name)['name'])
self.assertEqual(
rccg_name,
self.driver._helpers.get_rccg_info(mm_vol2.name)['name'])
self.assertEqual(fields.GroupStatus.AVAILABLE, model_update['status'])
self.assertEqual(fields.GroupStatus.AVAILABLE,
model_update['status'])
self.assertEqual([{'id': mm_vol1.id, 'group_id': group.id},
{'id': mm_vol2.id, 'group_id': group.id}],
add_volumes_update)
@ -12282,6 +12291,15 @@ class StorwizeSVCReplicationTestCase(test.TestCase):
(model_update, add_volumes_update,
remove_volumes_update) = self.driver.update_group(
self.ctxt, group, add_volumes=add_vols, remove_volumes=rmv_vols)
# Validating the rccg property value from metadata of the volume
# mm_vol3 that is added to a group
self.assertEqual(rccg_name, mm_vol3.metadata['Consistency Group Name'])
# Validating the rccg property value from metadata of the volume
# mm_vol1 that is removed from a group
exp_rccg_name = ''
self.assertEqual(exp_rccg_name,
mm_vol1.metadata['Consistency Group Name'])
self.assertIsNone(self.driver._helpers.get_rccg_info(mm_vol1.name))
self.assertIsNone(self.driver._helpers.get_rccg_info(mm_vol2.name))
self.assertEqual(
@ -12300,6 +12318,28 @@ class StorwizeSVCReplicationTestCase(test.TestCase):
self.driver.delete_group(self.ctxt, group, [mm_vol1, mm_vol2,
mm_vol3, mm_vol4])
def test_storwize_rep_volume_rccg_properties_update(self):
"""Test rep volume rccg_properties update."""
self.driver.configuration.set_override('replication_device',
[self.rep_target])
self.driver.do_setup(self.ctxt)
group = self._create_test_rccg(self.rccg_type, [self.mm_type.id])
# Create metro mirror replication.
mm_vol, model_update = self._create_test_volume(self.mm_type)
# Validating the rccg property value of volume-metadata that updated
# during the call to the function _update_rccg_properties by passing
# the parameter 'group'
self.driver._update_rccg_properties(self.ctxt, mm_vol, group)
rccg_name = self.driver._get_rccg_name(group)
self.assertEqual(rccg_name, mm_vol.metadata['Consistency Group Name'])
# Validating the rccg property value of volume-metadata that updated
# during the call to the function _update_rccg_properties by not
# passing the parameter 'group'
self.driver._update_rccg_properties(self.ctxt, mm_vol)
exp_rccg_name = ""
self.assertEqual(exp_rccg_name,
mm_vol.metadata['Consistency Group Name'])
@mock.patch.object(storwize_svc_common.StorwizeSSH,
'startrcconsistgrp')
def test_storwize_enable_replication_error(self, startrccg):
@ -12939,13 +12979,17 @@ class StorwizeSVCReplicationTestCase(test.TestCase):
clone_volumes = self.db.volume_get_all_by_generic_group(
self.ctxt.elevated(), clone_group.id)
with mock.patch.object(
storwize_svc_common.StorwizeSVCCommonDriver,
'_update_rccg_properties'):
model_update, volumes_model_update = (
self.driver.create_group_from_src(self.ctxt, clone_group,
clone_volumes, None, None,
src_group,
src_volumes))
self.assertEqual(fields.GroupStatus.AVAILABLE, model_update['status'])
self.assertEqual(fields.GroupStatus.AVAILABLE,
model_update['status'])
for vol_model_update in volumes_model_update:
self.assertEqual(fields.VolumeStatus.AVAILABLE,
vol_model_update['status'])
@ -12980,14 +13024,16 @@ class StorwizeSVCReplicationTestCase(test.TestCase):
group_snapshot, snapshots = self._create_group_snapshot(
src_group.id, group_type_id=self.rccg_type.id)
with mock.patch.object(
storwize_svc_common.StorwizeSVCCommonDriver,
'_update_rccg_properties'):
model_update, volumes_model_update = (
self.driver.create_group_from_src(self.ctxt,
group_from_src_group_snapshot,
group_volumes,
group_snapshot,
snapshots, None, None))
self.driver.create_group_from_src(
self.ctxt, group_from_src_group_snapshot, group_volumes,
group_snapshot, snapshots, None, None))
self.assertEqual(fields.GroupStatus.AVAILABLE, model_update['status'])
self.assertEqual(fields.GroupStatus.AVAILABLE,
model_update['status'])
for vol_model_update in volumes_model_update:
self.assertEqual(fields.VolumeStatus.AVAILABLE,
vol_model_update['status'])
@ -13040,7 +13086,9 @@ class StorwizeSVCReplicationTestCase(test.TestCase):
)
@mock.patch('oslo_service.loopingcall.FixedIntervalLoopingCall',
new=testutils.ZeroIntervalLoopingCall)
def test_create_group_from_src_grp(self, vol_spec):
@mock.patch.object(storwize_svc_common.StorwizeSVCCommonDriver,
'_update_rccg_properties')
def test_create_group_from_src_grp(self, vol_spec, update_rccg_properties):
self.driver.configuration.set_override('replication_device',
[self.rep_target])
@ -13154,9 +13202,12 @@ class StorwizeSVCReplicationTestCase(test.TestCase):
)
@mock.patch('oslo_service.loopingcall.FixedIntervalLoopingCall',
new=testutils.ZeroIntervalLoopingCall)
@mock.patch.object(storwize_svc_common.StorwizeSVCCommonDriver,
'_update_rccg_properties')
@mock.patch('cinder.volume.volume_utils.is_group_a_cg_snapshot_type')
def test_create_group_from_grp_snapshot(self, vol_spec,
is_group_a_cg_snap_type):
is_group_a_cg_snap_type,
update_rccg_properties):
self.driver.configuration.set_override('replication_device',
[self.rep_target])
is_group_a_cg_snap_type.return_value = False

View File

@ -3508,6 +3508,13 @@ class StorwizeSVCCommonDriver(san.SanDriver,
model_update['metadata'][key] = rel_info.get(value)
return model_update
def _update_rccg_properties(self, ctxt, volume, group=None):
rccg_name = self._get_rccg_name(group) if group else ""
if not volume.metadata:
volume.metadata = dict()
volume.metadata['Consistency Group Name'] = rccg_name
volume.save()
def create_volume(self, volume):
LOG.debug('enter: create_volume: volume %s', volume['name'])
# Create a replication or hyperswap volume with group_id is not
@ -6341,6 +6348,8 @@ class StorwizeSVCCommonDriver(san.SanDriver,
rccg = self._helpers.get_rccg(rccg_name)
added_vols.append({'id': volume.id,
'group_id': group.id})
# Updating RCCG properties for a volume
self._update_rccg_properties(context, volume, group)
except exception.VolumeBackendAPIException as err:
model_update['status'] = fields.GroupStatus.ERROR
LOG.error("Failed to add the remote copy of volume %(vol)s to "
@ -6372,6 +6381,8 @@ class StorwizeSVCCommonDriver(san.SanDriver,
self._helpers.chrcrelationship(rcrel['name'])
removed_vols.append({'id': volume.id,
'group_id': None})
# Updating RCCG properties for a volume
self._update_rccg_properties(context, volume)
except exception.VolumeBackendAPIException as err:
model_update['status'] = fields.GroupStatus.ERROR
LOG.error("Failed to remove the remote copy of volume %(vol)s "

View File

@ -0,0 +1,7 @@
---
fixes:
- |
IBM Spectrum Virtualize Family driver
`Bug #1926491 <https://bugs.launchpad.net/cinder/+bug/1926491>`_:
Updating volume metadata with rccg properties for the volumes with
replication enabled and added to a group or removed from a group.