PowerMax Driver - Manage volume into correct storage group
Manage a volume into the correct storage group if the name of the SRP on the remote differs to the SRP on the local array. For backward compatibility and name matching, the default storage group will assume the SRP name of the local array on both arrays. Closes-Bug: #1979666 Change-Id: Ie735b4a8607529ef3334242fd5a90c58f145adb4
This commit is contained in:
parent
9a8583b2ef
commit
8a890c8369
@ -4782,3 +4782,56 @@ class PowerMaxCommonTest(test.TestCase):
|
|||||||
self.data.array, 'vol_name', self.data.device_id,
|
self.data.array, 'vol_name', self.data.device_id,
|
||||||
self.data.extra_specs)
|
self.data.extra_specs)
|
||||||
mock_clean.assert_called_once()
|
mock_clean.assert_called_once()
|
||||||
|
|
||||||
|
@mock.patch.object(rest.PowerMaxRest, 'srdf_create_device_pair',
|
||||||
|
return_value={
|
||||||
|
'tgt_device': tpd.PowerMaxData.device_id2})
|
||||||
|
@mock.patch.object(rest.PowerMaxRest, 'get_rdf_group',
|
||||||
|
return_value=tpd.PowerMaxData.rdf_group_details)
|
||||||
|
@mock.patch.object(
|
||||||
|
common.PowerMaxCommon, '_get_replication_extra_specs',
|
||||||
|
return_value=tpd.PowerMaxData.rep_extra_specs_rep_config)
|
||||||
|
@mock.patch.object(common.PowerMaxCommon, 'get_rdf_details',
|
||||||
|
return_value=(10, tpd.PowerMaxData.remote_array))
|
||||||
|
def test_configure_volume_replication_srp_same(
|
||||||
|
self, mock_rdf, mock_res, mock_rdf_grp, mock_pair):
|
||||||
|
volume = fake_volume.fake_volume_obj(
|
||||||
|
context='cxt', provider_location=None)
|
||||||
|
with mock.patch.object(
|
||||||
|
self.masking,
|
||||||
|
'get_or_create_default_storage_group') as mock_sg:
|
||||||
|
self.common.configure_volume_replication(
|
||||||
|
self.data.array, volume, self.data.device_id,
|
||||||
|
self.data.rep_extra_specs_rep_config)
|
||||||
|
mock_sg.assert_called_with(
|
||||||
|
self.data.remote_array, self.data.srp, 'Diamond', 'DSS',
|
||||||
|
self.data.rep_extra_specs_rep_config, False, is_re=True,
|
||||||
|
rep_mode='Synchronous')
|
||||||
|
|
||||||
|
@mock.patch.object(rest.PowerMaxRest, 'srdf_create_device_pair',
|
||||||
|
return_value={
|
||||||
|
'tgt_device': tpd.PowerMaxData.device_id2})
|
||||||
|
@mock.patch.object(rest.PowerMaxRest, 'get_rdf_group',
|
||||||
|
return_value=tpd.PowerMaxData.rdf_group_details)
|
||||||
|
@mock.patch.object(
|
||||||
|
common.PowerMaxCommon, '_get_replication_extra_specs',
|
||||||
|
return_value=tpd.PowerMaxData.rep_extra_specs_rep_config)
|
||||||
|
@mock.patch.object(common.PowerMaxCommon, 'get_rdf_details',
|
||||||
|
return_value=(10, tpd.PowerMaxData.remote_array))
|
||||||
|
def test_configure_volume_replication_srp_diff(
|
||||||
|
self, mock_rdf, mock_res, mock_rdf_grp, mock_pair):
|
||||||
|
volume = fake_volume.fake_volume_obj(
|
||||||
|
context='cxt', provider_location=None)
|
||||||
|
|
||||||
|
rep_extra_specs = deepcopy(self.data.rep_extra_specs_rep_config)
|
||||||
|
rep_extra_specs.update({'srp': 'REMOTE_SRP'})
|
||||||
|
with mock.patch.object(
|
||||||
|
self.masking,
|
||||||
|
'get_or_create_default_storage_group') as mock_sg:
|
||||||
|
self.common.configure_volume_replication(
|
||||||
|
self.data.array, volume, self.data.device_id,
|
||||||
|
self.data.rep_extra_specs_rep_config)
|
||||||
|
mock_sg.assert_called_with(
|
||||||
|
self.data.remote_array, self.data.srp, 'Diamond', 'DSS',
|
||||||
|
self.data.rep_extra_specs_rep_config, False, is_re=True,
|
||||||
|
rep_mode='Synchronous')
|
||||||
|
@ -5039,8 +5039,16 @@ class PowerMaxCommon(object):
|
|||||||
device_uuid = self.utils.get_volume_element_name(volume.id)
|
device_uuid = self.utils.get_volume_element_name(volume.id)
|
||||||
self.rest.rename_volume(remote_array, r2_device_id, device_uuid)
|
self.rest.rename_volume(remote_array, r2_device_id, device_uuid)
|
||||||
|
|
||||||
|
if rep_extra_specs['srp'].lower() != extra_specs['srp'].lower():
|
||||||
|
LOG.warning("The source %(src)s and target %(tgt)s array SRPs "
|
||||||
|
"are different.", {'src': extra_specs['srp'],
|
||||||
|
'tgt': rep_extra_specs['srp']})
|
||||||
|
target_srp = extra_specs['srp']
|
||||||
|
else:
|
||||||
|
target_srp = rep_extra_specs['srp']
|
||||||
|
|
||||||
tgt_sg_name = self.masking.get_or_create_default_storage_group(
|
tgt_sg_name = self.masking.get_or_create_default_storage_group(
|
||||||
remote_array, rep_extra_specs['srp'], rep_extra_specs['slo'],
|
remote_array, target_srp, rep_extra_specs['slo'],
|
||||||
rep_extra_specs['workload'], rep_extra_specs,
|
rep_extra_specs['workload'], rep_extra_specs,
|
||||||
disable_compression, is_re=True, rep_mode=rep_mode)
|
disable_compression, is_re=True, rep_mode=rep_mode)
|
||||||
remote_sg_get = True
|
remote_sg_get = True
|
||||||
@ -5707,6 +5715,12 @@ class PowerMaxCommon(object):
|
|||||||
rep_extra_specs = deepcopy(extra_specs)
|
rep_extra_specs = deepcopy(extra_specs)
|
||||||
rep_extra_specs[utils.ARRAY] = rep_config['array']
|
rep_extra_specs[utils.ARRAY] = rep_config['array']
|
||||||
rep_extra_specs[utils.SRP] = rep_config['srp']
|
rep_extra_specs[utils.SRP] = rep_config['srp']
|
||||||
|
if extra_specs[utils.SRP].lower() != (
|
||||||
|
rep_extra_specs[utils.SRP].lower()):
|
||||||
|
LOG.warning("The source %(src)s and target %(tgt)s array SRPs "
|
||||||
|
"are different.", {'src': extra_specs[utils.SRP],
|
||||||
|
'tgt': rep_extra_specs[utils.SRP]})
|
||||||
|
|
||||||
rep_extra_specs[utils.PORTGROUPNAME] = rep_config['portgroup']
|
rep_extra_specs[utils.PORTGROUPNAME] = rep_config['portgroup']
|
||||||
|
|
||||||
# Get the RDF Group label & number
|
# Get the RDF Group label & number
|
||||||
|
8
releasenotes/notes/diff-srps-674f2c0cc893db4b.yaml
Normal file
8
releasenotes/notes/diff-srps-674f2c0cc893db4b.yaml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
`Bug #1979666 <https://bugs.launchpad.net/cinder/+bug/1979666>`_:
|
||||||
|
PowerMax driver : Fixed rare case where the SRP in the local and
|
||||||
|
remote arrays are different when managing volumes into OpenStack.
|
||||||
|
For backward compatibility and name matching, the default storage
|
||||||
|
group will assume the SRP name of the local array on both arrays.
|
Loading…
Reference in New Issue
Block a user