Merge "PowerMax Driver - Fix for deleting replication group"
This commit is contained in:
commit
ba27068fc0
@ -2350,6 +2350,8 @@ class PowerMaxCommonTest(test.TestCase):
|
|||||||
array_id, volume, device_id, srp, target_slo, target_workload,
|
array_id, volume, device_id, srp, target_slo, target_workload,
|
||||||
volume_name, new_type, extra_specs)
|
volume_name, new_type, extra_specs)
|
||||||
|
|
||||||
|
@mock.patch.object(rest.PowerMaxRest, 'get_storage_group_rdf_group_state',
|
||||||
|
return_value=['activebias'])
|
||||||
@mock.patch.object(common.PowerMaxCommon,
|
@mock.patch.object(common.PowerMaxCommon,
|
||||||
'_post_retype_srdf_protect_storage_group',
|
'_post_retype_srdf_protect_storage_group',
|
||||||
return_value=(True, True, True))
|
return_value=(True, True, True))
|
||||||
@ -2369,7 +2371,7 @@ class PowerMaxCommonTest(test.TestCase):
|
|||||||
return_value=True)
|
return_value=True)
|
||||||
def test_cleanup_on_migrate_failure(
|
def test_cleanup_on_migrate_failure(
|
||||||
self, mck_rep_enabled, mck_retype_remote, mck_break, mck_resume,
|
self, mck_rep_enabled, mck_retype_remote, mck_break, mck_resume,
|
||||||
mck_retype, mck_configure, mck_get_vname, mck_protect):
|
mck_retype, mck_configure, mck_get_vname, mck_protect, mck_states):
|
||||||
rdf_pair_broken = True
|
rdf_pair_broken = True
|
||||||
rdf_pair_created = True
|
rdf_pair_created = True
|
||||||
vol_retyped = True
|
vol_retyped = True
|
||||||
|
@ -1449,6 +1449,11 @@ class PowerMaxReplicationTest(test.TestCase):
|
|||||||
self.common.cleanup_rdf_device_pair, array, rdf_group_no,
|
self.common.cleanup_rdf_device_pair, array, rdf_group_no,
|
||||||
device_id, extra_specs)
|
device_id, extra_specs)
|
||||||
|
|
||||||
|
@mock.patch.object(rest.PowerMaxRest, 'get_storage_group_rdf_group_state',
|
||||||
|
return_value=['activebias'])
|
||||||
|
@mock.patch.object(
|
||||||
|
rest.PowerMaxRest, 'is_volume_in_storagegroup',
|
||||||
|
return_value=True)
|
||||||
@mock.patch.object(
|
@mock.patch.object(
|
||||||
rest.PowerMaxRest, 'srdf_resume_replication')
|
rest.PowerMaxRest, 'srdf_resume_replication')
|
||||||
@mock.patch.object(
|
@mock.patch.object(
|
||||||
@ -1484,7 +1489,8 @@ class PowerMaxReplicationTest(test.TestCase):
|
|||||||
def test_cleanup_rdf_device_pair(
|
def test_cleanup_rdf_device_pair(
|
||||||
self, mck_get_rdf, mck_get_rep, mck_get_rdf_pair, mck_get_sg_list,
|
self, mck_get_rdf, mck_get_rep, mck_get_rdf_pair, mck_get_sg_list,
|
||||||
mck_wait, mck_get_mgmt_grp, mck_get_num_vols, mck_suspend,
|
mck_wait, mck_get_mgmt_grp, mck_get_num_vols, mck_suspend,
|
||||||
mck_srdf_remove, mck_remove, mck_delete, mck_cleanup, mck_resume):
|
mck_srdf_remove, mck_remove, mck_delete, mck_cleanup, mck_resume,
|
||||||
|
mock_is_vol, mock_states):
|
||||||
array = self.data.array
|
array = self.data.array
|
||||||
rdf_group_no = self.data.rdf_group_no_1
|
rdf_group_no = self.data.rdf_group_no_1
|
||||||
device_id = self.data.device_id
|
device_id = self.data.device_id
|
||||||
|
@ -5819,14 +5819,13 @@ class PowerMaxCommon(object):
|
|||||||
group_details = self.rest.get_storage_group_rep(
|
group_details = self.rest.get_storage_group_rep(
|
||||||
array, vol_grp_name)
|
array, vol_grp_name)
|
||||||
if group_details and group_details.get('rdf', False):
|
if group_details and group_details.get('rdf', False):
|
||||||
if extra_specs['rep_mode'] in [utils.REP_ASYNC, utils.REP_METRO]:
|
self.rest.srdf_suspend_replication(
|
||||||
self.rest.srdf_suspend_replication(
|
array, vol_grp_name, rdf_group_no, extra_specs)
|
||||||
array, vol_grp_name, rdf_group_no, extra_specs)
|
if volume_device_ids:
|
||||||
if volume_device_ids:
|
LOG.debug("Deleting remote replication for group %(sg)s", {
|
||||||
LOG.debug("Deleting remote replication for group %(sg)s", {
|
'sg': vol_grp_name})
|
||||||
'sg': vol_grp_name})
|
self.rest.delete_storagegroup_rdf(array, vol_grp_name,
|
||||||
self.rest.delete_storagegroup_rdf(array, vol_grp_name,
|
rdf_group_no)
|
||||||
rdf_group_no)
|
|
||||||
remote_device_ids = self._get_members_of_volume_group(
|
remote_device_ids = self._get_members_of_volume_group(
|
||||||
remote_array, vol_grp_name)
|
remote_array, vol_grp_name)
|
||||||
# Remove volumes from remote replication group
|
# Remove volumes from remote replication group
|
||||||
@ -5841,7 +5840,8 @@ class PowerMaxCommon(object):
|
|||||||
self._delete_from_srp(
|
self._delete_from_srp(
|
||||||
remote_array, device_id, "group vol", extra_specs)
|
remote_array, device_id, "group vol", extra_specs)
|
||||||
# Once all volumes are deleted then delete the SG
|
# Once all volumes are deleted then delete the SG
|
||||||
self.rest.delete_storage_group(remote_array, vol_grp_name)
|
if self.rest.get_storage_group(remote_array, vol_grp_name):
|
||||||
|
self.rest.delete_storage_group(remote_array, vol_grp_name)
|
||||||
|
|
||||||
def create_group_snapshot(self, context, group_snapshot, snapshots):
|
def create_group_snapshot(self, context, group_snapshot, snapshots):
|
||||||
"""Creates a generic volume group snapshot.
|
"""Creates a generic volume group snapshot.
|
||||||
|
@ -3231,8 +3231,10 @@ class PowerMaxRest(object):
|
|||||||
resource_name = ('%(sg_name)s/rdf_group/%(rdf_num)s'
|
resource_name = ('%(sg_name)s/rdf_group/%(rdf_num)s'
|
||||||
% {'sg_name': storagegroup_name,
|
% {'sg_name': storagegroup_name,
|
||||||
'rdf_num': rdf_group_num})
|
'rdf_num': rdf_group_num})
|
||||||
|
query_params = {'force': 'true'}
|
||||||
self.delete_resource(
|
self.delete_resource(
|
||||||
array, REPLICATION, 'storagegroup', resource_name=resource_name)
|
array, REPLICATION, 'storagegroup', resource_name=resource_name,
|
||||||
|
params=query_params)
|
||||||
|
|
||||||
def list_pagination(self, list_info):
|
def list_pagination(self, list_info):
|
||||||
"""Process lists under or over the maxPageSize
|
"""Process lists under or over the maxPageSize
|
||||||
|
@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
PowerMax driver:
|
||||||
|
Fix to suspend the storage group you are about to delete
|
||||||
|
and then add a force flag to delete the volume pairs within
|
||||||
|
the storage group.
|
Loading…
x
Reference in New Issue
Block a user