Merge "[SVf] Adding Support for --delete-volumes flag for delete volume group"
This commit is contained in:
commit
e096b2db0e
@ -7257,7 +7257,7 @@ class StorwizeSVCCommonDriverTestCase(test.TestCase):
|
|||||||
self.assertEqual(fields.GroupStatus.AVAILABLE,
|
self.assertEqual(fields.GroupStatus.AVAILABLE,
|
||||||
model_update['status'])
|
model_update['status'])
|
||||||
# Delete Volume Group
|
# Delete Volume Group
|
||||||
model_update = self.driver.delete_group(self.ctxt, volumegroup, None)
|
model_update = self.driver.delete_group(self.ctxt, volumegroup, [])
|
||||||
self.assertTrue(delete_volumegroup.called)
|
self.assertTrue(delete_volumegroup.called)
|
||||||
self.assertEqual(fields.GroupStatus.DELETED,
|
self.assertEqual(fields.GroupStatus.DELETED,
|
||||||
model_update[0]['status'])
|
model_update[0]['status'])
|
||||||
@ -7374,7 +7374,7 @@ class StorwizeSVCCommonDriverTestCase(test.TestCase):
|
|||||||
|
|
||||||
# Delete Volume Group
|
# Delete Volume Group
|
||||||
model_update = self.driver.delete_group(self.ctxt, volumegroup,
|
model_update = self.driver.delete_group(self.ctxt, volumegroup,
|
||||||
None)
|
[])
|
||||||
self.assertTrue(delete_volumegroup.called)
|
self.assertTrue(delete_volumegroup.called)
|
||||||
self.assertEqual(fields.GroupStatus.DELETED,
|
self.assertEqual(fields.GroupStatus.DELETED,
|
||||||
model_update[0]['status'])
|
model_update[0]['status'])
|
||||||
@ -7461,6 +7461,66 @@ class StorwizeSVCCommonDriverTestCase(test.TestCase):
|
|||||||
self.assertEqual(fields.GroupStatus.DELETED,
|
self.assertEqual(fields.GroupStatus.DELETED,
|
||||||
model_update[0]['status'])
|
model_update[0]['status'])
|
||||||
|
|
||||||
|
@mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
|
'get_system_info')
|
||||||
|
def test_storwize_delete_volumegroup_with_delete_volumes(self,
|
||||||
|
get_system_info):
|
||||||
|
"""Test volume group creation and deletion"""
|
||||||
|
|
||||||
|
fake_system_info = {'code_level': (8, 5, 1, 0),
|
||||||
|
'system_name': 'storwize-svc-sim',
|
||||||
|
'system_id': '0123456789ABCDEF'}
|
||||||
|
get_system_info.return_value = fake_system_info
|
||||||
|
self.driver.do_setup(None)
|
||||||
|
|
||||||
|
# Seting the storwize_volume_group to True
|
||||||
|
self._set_flag('storwize_volume_group', True)
|
||||||
|
|
||||||
|
# Create volumegroup type
|
||||||
|
volumegroup_spec = {'volume_group_enabled': '<is> True'}
|
||||||
|
volumegroup_type_ref = group_types.create(self.ctxt,
|
||||||
|
'volumegroup_type',
|
||||||
|
volumegroup_spec)
|
||||||
|
volumegroup_type = objects.GroupType.get_by_id(
|
||||||
|
self.ctxt, volumegroup_type_ref['id'])
|
||||||
|
|
||||||
|
# Create source volume
|
||||||
|
vol_type_ref = volume_types.create(self.ctxt, 'non_rep_type', {})
|
||||||
|
vol_type = objects.VolumeType.get_by_id(self.ctxt,
|
||||||
|
vol_type_ref['id'])
|
||||||
|
source_vol = self._generate_vol_info(vol_type)
|
||||||
|
self.driver.create_volume(source_vol)
|
||||||
|
|
||||||
|
# Create source volumegroup
|
||||||
|
source_volumegroup = testutils.create_group(
|
||||||
|
self.ctxt, group_type_id=volumegroup_type.id,
|
||||||
|
volume_type_ids=[vol_type_ref['id']])
|
||||||
|
|
||||||
|
model_update = self.driver.create_group(self.ctxt, source_volumegroup)
|
||||||
|
self.assertEqual(fields.GroupStatus.AVAILABLE,
|
||||||
|
model_update['status'])
|
||||||
|
|
||||||
|
# Add source volumes to source volumegroup
|
||||||
|
(model_update, add_volumes_update, remove_volumes_update) = (
|
||||||
|
self.driver.update_group(self.ctxt, source_volumegroup,
|
||||||
|
[source_vol], []))
|
||||||
|
|
||||||
|
self.assertEqual(fields.GroupStatus.AVAILABLE,
|
||||||
|
model_update['status'])
|
||||||
|
source_volumegroup_name = self.driver._get_volumegroup_name(
|
||||||
|
source_volumegroup)
|
||||||
|
self.assertEqual(source_volumegroup_name,
|
||||||
|
source_vol.metadata['Volume Group Name'])
|
||||||
|
|
||||||
|
# Delete Volume Group
|
||||||
|
model_update = self.driver.delete_group(self.ctxt,
|
||||||
|
source_volumegroup,
|
||||||
|
[source_vol])
|
||||||
|
self.assertEqual(fields.GroupStatus.DELETED,
|
||||||
|
model_update[0]['status'])
|
||||||
|
for volume in model_update[1]:
|
||||||
|
self.assertEqual('deleted', volume['status'])
|
||||||
|
|
||||||
@mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
@mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
'get_system_info')
|
'get_system_info')
|
||||||
@mock.patch.object(cinder.volume.volume_utils,
|
@mock.patch.object(cinder.volume.volume_utils,
|
||||||
|
@ -2921,6 +2921,18 @@ class StorwizeHelpers(object):
|
|||||||
return
|
return
|
||||||
self.ssh.rmsnapshot(params)
|
self.ssh.rmsnapshot(params)
|
||||||
|
|
||||||
|
def get_volume_name_from_metadata(self, volume):
|
||||||
|
"""Get Volume name from metadata if metadata exists"""
|
||||||
|
if volume.metadata:
|
||||||
|
svc_volume_name = volume.metadata.get("Volume Name", None)
|
||||||
|
if svc_volume_name:
|
||||||
|
LOG.info('Volume %(cinder_id)s in cinder API is linked to '
|
||||||
|
'volume_name %(svc_volume_name)s in SVC',
|
||||||
|
{'cinder_id': volume.name,
|
||||||
|
'svc_volume_name': svc_volume_name})
|
||||||
|
volume.name_id = svc_volume_name.split("-", 1)[1]
|
||||||
|
return volume
|
||||||
|
|
||||||
def get_partnership_info(self, system_name):
|
def get_partnership_info(self, system_name):
|
||||||
partnership = self.ssh.lspartnership(system_name)
|
partnership = self.ssh.lspartnership(system_name)
|
||||||
return partnership[0] if len(partnership) > 0 else None
|
return partnership[0] if len(partnership) > 0 else None
|
||||||
@ -6375,7 +6387,8 @@ class StorwizeSVCCommonDriver(san.SanDriver,
|
|||||||
elif volume_utils.is_group_a_type(group, "volume_group_enabled"):
|
elif volume_utils.is_group_a_type(group, "volume_group_enabled"):
|
||||||
self._helpers.check_codelevel_for_volumegroup(
|
self._helpers.check_codelevel_for_volumegroup(
|
||||||
self._state['code_level'])
|
self._state['code_level'])
|
||||||
model_update = self._delete_volumegroup(group)
|
model_update, volumes_model_update = self._delete_volumegroup(
|
||||||
|
group, volumes)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
for volume in volumes:
|
for volume in volumes:
|
||||||
@ -7102,9 +7115,41 @@ class StorwizeSVCCommonDriver(san.SanDriver,
|
|||||||
{'vol': volume.name, 'exception': err})
|
{'vol': volume.name, 'exception': err})
|
||||||
return model_update, added_vols, removed_vols
|
return model_update, added_vols, removed_vols
|
||||||
|
|
||||||
def _delete_volumegroup(self, group):
|
def _delete_volumegroup(self, group, volumes):
|
||||||
model_update = {'status': fields.GroupStatus.DELETED}
|
model_update = {'status': fields.GroupStatus.DELETED}
|
||||||
volumegroup_name = self._get_volumegroup_name(group)
|
volumegroup_name = self._get_volumegroup_name(group)
|
||||||
|
volumes_model_update = []
|
||||||
|
force_unmap = True
|
||||||
|
if self._state['code_level'] < (7, 7, 0, 0):
|
||||||
|
force_unmap = False
|
||||||
|
for volume in volumes:
|
||||||
|
volume = self._helpers.get_volume_name_from_metadata(volume)
|
||||||
|
if self._active_backend_id:
|
||||||
|
msg = (_('Error: deleting non-replicated volume in '
|
||||||
|
'failover mode is not allowed.'))
|
||||||
|
LOG.error(msg)
|
||||||
|
volume.name_id = None
|
||||||
|
raise exception.VolumeDriverException(message=msg)
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
self._helpers.delete_vdisk(
|
||||||
|
volume.name,
|
||||||
|
force_unmap=force_unmap,
|
||||||
|
force_delete=True)
|
||||||
|
volumes_model_update.append({'id': volume.id,
|
||||||
|
'status': 'deleted'})
|
||||||
|
except exception.VolumeBackendAPIException as err:
|
||||||
|
model_update['status'] = (
|
||||||
|
fields.GroupStatus.ERROR_DELETING)
|
||||||
|
LOG.error("Failed to delete the volume %(vol)s of CG. "
|
||||||
|
"Exception: %(exception)s.",
|
||||||
|
{'vol': volume.name, 'exception': err})
|
||||||
|
volume.name_id = None
|
||||||
|
volumes_model_update.append(
|
||||||
|
{'id': volume.id,
|
||||||
|
'status': fields.GroupStatus.ERROR_DELETING})
|
||||||
|
volume.name_id = None
|
||||||
|
|
||||||
try:
|
try:
|
||||||
self._helpers.delete_volumegroup(volumegroup_name)
|
self._helpers.delete_volumegroup(volumegroup_name)
|
||||||
except exception.VolumeBackendAPIException as err:
|
except exception.VolumeBackendAPIException as err:
|
||||||
@ -7113,7 +7158,7 @@ class StorwizeSVCCommonDriver(san.SanDriver,
|
|||||||
{'volumegroup': volumegroup_name, 'exception': err})
|
{'volumegroup': volumegroup_name, 'exception': err})
|
||||||
model_update = {'status': fields.GroupStatus.ERROR_DELETING}
|
model_update = {'status': fields.GroupStatus.ERROR_DELETING}
|
||||||
|
|
||||||
return model_update
|
return model_update, volumes_model_update
|
||||||
|
|
||||||
def _update_volumegroup(self, context, group, add_volumes,
|
def _update_volumegroup(self, context, group, add_volumes,
|
||||||
remove_volumes):
|
remove_volumes):
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- |
|
||||||
|
IBM Spectrum Virtualize Family driver: Added `--delete-volumes` flag
|
||||||
|
support for delete volumegroup operation. After adding support,
|
||||||
|
the volumes can optionally be deleted when the volume group is deleted.
|
Loading…
x
Reference in New Issue
Block a user