[SVF]:Fix in change_vdisk_iogrp during retype
[Spectrum Virtualize Family] Fixed issues in change_vdisk_iogrp. During retyping a volume between I/O groups, if addvdiskaccess fails an exception is raised and if movevdisk fails rmvdiskaccess should be done for new I/O group before failing the retype operation. Closes bug: #1896214 Change-Id: Ic1f770a7c7850c9897f42999968820eac4d6ed47
This commit is contained in:
parent
a9bc7dd6c5
commit
1145569343
@ -8201,6 +8201,92 @@ class StorwizeSVCCommonDriverTestCase(test.TestCase):
|
|||||||
|
|
||||||
delete_vdisk.assert_has_calls(calls, any_order=True)
|
delete_vdisk.assert_has_calls(calls, any_order=True)
|
||||||
|
|
||||||
|
def test_storwize_svc_retype_between_iogrps(self):
|
||||||
|
self.driver.do_setup(None)
|
||||||
|
ctxt = context.get_admin_context()
|
||||||
|
|
||||||
|
key_specs_old = {'iogrp': 0}
|
||||||
|
key_specs_new = {'iogrp': 1}
|
||||||
|
old_type_ref = volume_types.create(ctxt, 'old', key_specs_old)
|
||||||
|
new_type_ref = volume_types.create(ctxt, 'new', key_specs_new)
|
||||||
|
|
||||||
|
diff, _equal = volume_types.volume_types_diff(ctxt, old_type_ref['id'],
|
||||||
|
new_type_ref['id'])
|
||||||
|
|
||||||
|
old_type = objects.VolumeType.get_by_id(ctxt,
|
||||||
|
old_type_ref['id'])
|
||||||
|
volume = self._generate_vol_info(old_type)
|
||||||
|
new_type = objects.VolumeType.get_by_id(ctxt,
|
||||||
|
new_type_ref['id'])
|
||||||
|
|
||||||
|
self.driver.create_volume(volume)
|
||||||
|
conn = {'initiator': u'iqn.1993-08.org.debian:01:eac5ccc1aaa',
|
||||||
|
'ip': '10.10.10.12',
|
||||||
|
'host': u'openstack@svc#openstack'}
|
||||||
|
self.driver.initialize_connection(volume, conn)
|
||||||
|
loc = ('StorwizeSVCDriver:' + self.driver._state['system_id'] +
|
||||||
|
':openstack2')
|
||||||
|
cap = {'location_info': loc, 'extent_size': '128'}
|
||||||
|
host_name = self.driver._helpers.get_host_from_connector(
|
||||||
|
conn, iscsi=True)
|
||||||
|
self.assertIsNotNone(host_name)
|
||||||
|
host = {'host': host_name, 'capabilities': cap}
|
||||||
|
volume['host'] = host['host']
|
||||||
|
|
||||||
|
self.driver.retype(ctxt, volume, new_type, diff, host)
|
||||||
|
attrs = self.driver._helpers.get_vdisk_attributes(volume['name'])
|
||||||
|
self.assertEqual('1', attrs['IO_group_id'], 'Volume retype '
|
||||||
|
'failed')
|
||||||
|
|
||||||
|
@mock.patch.object(storwize_svc_common.StorwizeSSH, 'addvdiskaccess')
|
||||||
|
@mock.patch.object(storwize_svc_common.StorwizeSSH, 'rmvdiskaccess')
|
||||||
|
@mock.patch.object(storwize_svc_common.StorwizeSSH, 'movevdisk')
|
||||||
|
def test_storwize_svc_retype_between_iogrps_invalid(
|
||||||
|
self, movevdisk, rmvdiskaccess, addvdiskaccess):
|
||||||
|
self.driver.do_setup(None)
|
||||||
|
ctxt = context.get_admin_context()
|
||||||
|
|
||||||
|
key_specs_old = {'iogrp': 0}
|
||||||
|
key_specs_new = {'iogrp': 1}
|
||||||
|
old_type_ref = volume_types.create(ctxt, 'old', key_specs_old)
|
||||||
|
new_type_ref = volume_types.create(ctxt, 'new', key_specs_new)
|
||||||
|
|
||||||
|
diff, _equal = volume_types.volume_types_diff(ctxt, old_type_ref['id'],
|
||||||
|
new_type_ref['id'])
|
||||||
|
|
||||||
|
old_type = objects.VolumeType.get_by_id(ctxt,
|
||||||
|
old_type_ref['id'])
|
||||||
|
volume = self._generate_vol_info(old_type)
|
||||||
|
new_type = objects.VolumeType.get_by_id(ctxt,
|
||||||
|
new_type_ref['id'])
|
||||||
|
|
||||||
|
self.driver.create_volume(volume)
|
||||||
|
conn = {'initiator': u'iqn.1993-08.org.debian:01:eac5ccc1aaa',
|
||||||
|
'ip': '10.10.10.12',
|
||||||
|
'host': u'openstack@svc#openstack'}
|
||||||
|
self.driver.initialize_connection(volume, conn)
|
||||||
|
loc = ('StorwizeSVCDriver:' + self.driver._state['system_id'] +
|
||||||
|
':openstack2')
|
||||||
|
cap = {'location_info': loc, 'extent_size': '128'}
|
||||||
|
host_name = self.driver._helpers.get_host_from_connector(
|
||||||
|
conn, iscsi=True)
|
||||||
|
self.assertIsNotNone(host_name)
|
||||||
|
host = {'host': host_name, 'capabilities': cap}
|
||||||
|
volume['host'] = host['host']
|
||||||
|
ex = exception.VolumeBackendAPIException(data='CMMVC5879E')
|
||||||
|
movevdisk.side_effect = ex
|
||||||
|
|
||||||
|
self.assertRaises(exception.VolumeBackendAPIException,
|
||||||
|
self.driver.retype, ctxt,
|
||||||
|
volume, new_type, diff, host)
|
||||||
|
attrs = self.driver._helpers.get_vdisk_attributes(volume['name'])
|
||||||
|
self.assertEqual(int(key_specs_old['iogrp']),
|
||||||
|
int(attrs['IO_group_id']), 'Volume retype failed')
|
||||||
|
addvdiskaccess.assert_called()
|
||||||
|
movevdisk.assert_called()
|
||||||
|
rmvdiskaccess.assert_called_with(
|
||||||
|
volume['name'], str(key_specs_new['iogrp']))
|
||||||
|
|
||||||
|
|
||||||
class CLIResponseTestCase(test.TestCase):
|
class CLIResponseTestCase(test.TestCase):
|
||||||
def test_empty(self):
|
def test_empty(self):
|
||||||
|
@ -2480,8 +2480,17 @@ class StorwizeHelpers(object):
|
|||||||
'%(code_level)s, below the required 6.4.0.0.',
|
'%(code_level)s, below the required 6.4.0.0.',
|
||||||
{'code_level': state['code_level']})
|
{'code_level': state['code_level']})
|
||||||
else:
|
else:
|
||||||
self.ssh.movevdisk(vdisk, str(iogrp[0]))
|
|
||||||
self.ssh.addvdiskaccess(vdisk, str(iogrp[0]))
|
self.ssh.addvdiskaccess(vdisk, str(iogrp[0]))
|
||||||
|
try:
|
||||||
|
self.ssh.movevdisk(vdisk, str(iogrp[0]))
|
||||||
|
except exception.VolumeBackendAPIException as e:
|
||||||
|
self.ssh.rmvdiskaccess(vdisk, str(iogrp[0]))
|
||||||
|
msg = (_('movevdisk command failed for %(vdisk),'
|
||||||
|
'performing rmdiskaccess for %(iogrp)s.'
|
||||||
|
'Exception: %(err)s.'),
|
||||||
|
{'vdisk': vdisk, 'iogrp': iogrp[0], 'err': e})
|
||||||
|
LOG.exception(msg)
|
||||||
|
raise exception.VolumeBackendAPIException(data=msg)
|
||||||
self.ssh.rmvdiskaccess(vdisk, str(iogrp[1]))
|
self.ssh.rmvdiskaccess(vdisk, str(iogrp[1]))
|
||||||
|
|
||||||
def vdisk_by_uid(self, vdisk_uid):
|
def vdisk_by_uid(self, vdisk_uid):
|
||||||
|
@ -0,0 +1,9 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
IBM Spectrum Virtualize Family `Bug #1896214
|
||||||
|
<https://bugs.launchpad.net/cinder/+bug/1896214>`_:
|
||||||
|
Fixed issues in change_vdisk_iogrp.
|
||||||
|
During retyping a volume between I/O groups, if addvdiskaccess fails
|
||||||
|
an exception is raised and if movevdisk fails rmvdiskaccess should be
|
||||||
|
done for new I/O group before failing the retype operation.
|
Loading…
Reference in New Issue
Block a user