Merge "Support hacking 6.1.0"
This commit is contained in:
commit
e9c18c7f94
@ -217,7 +217,7 @@ class APIVersionRequest(utils.ComparableMixin):
|
|||||||
def matches_versioned_method(self, method):
|
def matches_versioned_method(self, method):
|
||||||
"""Compares this version to that of a versioned method."""
|
"""Compares this version to that of a versioned method."""
|
||||||
|
|
||||||
if type(method) != versioned_method.VersionedMethod:
|
if type(method) is not versioned_method.VersionedMethod:
|
||||||
msg = _('An API version request must be compared '
|
msg = _('An API version request must be compared '
|
||||||
'to a VersionedMethod object.')
|
'to a VersionedMethod object.')
|
||||||
raise exception.InvalidParameterValue(err=msg)
|
raise exception.InvalidParameterValue(err=msg)
|
||||||
|
@ -945,7 +945,7 @@ class BackupCephTestCase(test.TestCase):
|
|||||||
src_snap = ''
|
src_snap = ''
|
||||||
with tempfile.NamedTemporaryFile() as dest_file:
|
with tempfile.NamedTemporaryFile() as dest_file:
|
||||||
with mock.patch.object(self.service,
|
with mock.patch.object(self.service,
|
||||||
'_transfer_data') as mock_transfer_data,\
|
'_transfer_data') as mock_transfer_data, \
|
||||||
mock.patch.object(self.service,
|
mock.patch.object(self.service,
|
||||||
'_get_backup_base_name') as mock_getbasename:
|
'_get_backup_base_name') as mock_getbasename:
|
||||||
|
|
||||||
@ -963,7 +963,7 @@ class BackupCephTestCase(test.TestCase):
|
|||||||
src_snap = 'random_snap'
|
src_snap = 'random_snap'
|
||||||
with tempfile.NamedTemporaryFile() as dest_file:
|
with tempfile.NamedTemporaryFile() as dest_file:
|
||||||
with mock.patch.object(self.service,
|
with mock.patch.object(self.service,
|
||||||
'_transfer_data') as mock_transfer_data,\
|
'_transfer_data') as mock_transfer_data, \
|
||||||
mock.patch.object(self.service,
|
mock.patch.object(self.service,
|
||||||
'_get_backup_base_name') as mock_getbasename:
|
'_get_backup_base_name') as mock_getbasename:
|
||||||
|
|
||||||
@ -993,7 +993,7 @@ class BackupCephTestCase(test.TestCase):
|
|||||||
|
|
||||||
with tempfile.NamedTemporaryFile() as dest_file:
|
with tempfile.NamedTemporaryFile() as dest_file:
|
||||||
with mock.patch.object(self.service,
|
with mock.patch.object(self.service,
|
||||||
'_transfer_data') as mock_transfer_data,\
|
'_transfer_data') as mock_transfer_data, \
|
||||||
mock.patch.object(self.service,
|
mock.patch.object(self.service,
|
||||||
'_get_backup_base_name') as mock_getbasename:
|
'_get_backup_base_name') as mock_getbasename:
|
||||||
|
|
||||||
@ -1010,7 +1010,7 @@ class BackupCephTestCase(test.TestCase):
|
|||||||
src_snap = None
|
src_snap = None
|
||||||
with tempfile.NamedTemporaryFile() as dest_file:
|
with tempfile.NamedTemporaryFile() as dest_file:
|
||||||
with mock.patch.object(self.service,
|
with mock.patch.object(self.service,
|
||||||
'_get_backup_base_name') as mock_name,\
|
'_get_backup_base_name') as mock_name, \
|
||||||
mock.patch('eventlet.tpool.Proxy') as mock_proxy:
|
mock.patch('eventlet.tpool.Proxy') as mock_proxy:
|
||||||
|
|
||||||
self.mock_rbd.Image.side_effect = self.mock_rbd.ImageNotFound
|
self.mock_rbd.Image.side_effect = self.mock_rbd.ImageNotFound
|
||||||
|
@ -76,7 +76,7 @@ class TestBaseISCSITargetDriver(tf.TargetDriverFixture):
|
|||||||
|
|
||||||
def test_do_iscsi_discovery(self):
|
def test_do_iscsi_discovery(self):
|
||||||
with mock.patch.object(self.configuration,
|
with mock.patch.object(self.configuration,
|
||||||
'safe_get', return_value='127.0.0.1'),\
|
'safe_get', return_value='127.0.0.1'), \
|
||||||
mock.patch('cinder.utils.execute',
|
mock.patch('cinder.utils.execute',
|
||||||
return_value=(self.target_string, '')):
|
return_value=(self.target_string, '')):
|
||||||
self.assertEqual(self.target_string,
|
self.assertEqual(self.target_string,
|
||||||
@ -85,8 +85,8 @@ class TestBaseISCSITargetDriver(tf.TargetDriverFixture):
|
|||||||
def test_remove_export(self):
|
def test_remove_export(self):
|
||||||
|
|
||||||
with mock.patch.object(self.target, '_get_target_and_lun') as \
|
with mock.patch.object(self.target, '_get_target_and_lun') as \
|
||||||
mock_get_target,\
|
mock_get_target, \
|
||||||
mock.patch.object(self.target, 'show_target'),\
|
mock.patch.object(self.target, 'show_target'), \
|
||||||
mock.patch.object(self.target, 'remove_iscsi_target') as \
|
mock.patch.object(self.target, 'remove_iscsi_target') as \
|
||||||
mock_remove_target:
|
mock_remove_target:
|
||||||
|
|
||||||
@ -103,8 +103,8 @@ class TestBaseISCSITargetDriver(tf.TargetDriverFixture):
|
|||||||
def test_remove_export_notfound(self):
|
def test_remove_export_notfound(self):
|
||||||
|
|
||||||
with mock.patch.object(self.target, '_get_target_and_lun') as \
|
with mock.patch.object(self.target, '_get_target_and_lun') as \
|
||||||
mock_get_target,\
|
mock_get_target, \
|
||||||
mock.patch.object(self.target, 'show_target'),\
|
mock.patch.object(self.target, 'show_target'), \
|
||||||
mock.patch.object(self.target, 'remove_iscsi_target'):
|
mock.patch.object(self.target, 'remove_iscsi_target'):
|
||||||
|
|
||||||
mock_get_target.side_effect = exception.NotFound
|
mock_get_target.side_effect = exception.NotFound
|
||||||
@ -115,8 +115,8 @@ class TestBaseISCSITargetDriver(tf.TargetDriverFixture):
|
|||||||
def test_remove_export_show_error(self):
|
def test_remove_export_show_error(self):
|
||||||
|
|
||||||
with mock.patch.object(self.target, '_get_target_and_lun') as \
|
with mock.patch.object(self.target, '_get_target_and_lun') as \
|
||||||
mock_get_target,\
|
mock_get_target, \
|
||||||
mock.patch.object(self.target, 'show_target') as mshow,\
|
mock.patch.object(self.target, 'show_target') as mshow, \
|
||||||
mock.patch.object(self.target, 'remove_iscsi_target'):
|
mock.patch.object(self.target, 'remove_iscsi_target'):
|
||||||
|
|
||||||
mock_get_target.return_value = (0, 1)
|
mock_get_target.return_value = (0, 1)
|
||||||
|
@ -43,7 +43,7 @@ class TestCxtAdmDriver(tf.TargetDriverFixture):
|
|||||||
|
|
||||||
def test_get_target(self):
|
def test_get_target(self):
|
||||||
with mock.patch.object(self.target, '_get_volumes_dir',
|
with mock.patch.object(self.target, '_get_volumes_dir',
|
||||||
return_value=self.fake_volumes_dir),\
|
return_value=self.fake_volumes_dir), \
|
||||||
mock.patch('cinder.utils.execute',
|
mock.patch('cinder.utils.execute',
|
||||||
return_value=(self.fake_iscsi_scan, None)) as m_exec:
|
return_value=(self.fake_iscsi_scan, None)) as m_exec:
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
|
@ -153,18 +153,19 @@ class TestSCSTAdmDriver(tf.TargetDriverFixture):
|
|||||||
'QZJbisGmn9AL954FNF4D P68eE7u9eFqDGexd28DQ'}
|
'QZJbisGmn9AL954FNF4D P68eE7u9eFqDGexd28DQ'}
|
||||||
|
|
||||||
with mock.patch.object(self.target, '_get_target_and_lun',
|
with mock.patch.object(self.target, '_get_target_and_lun',
|
||||||
side_effect=_fake_get_target_and_lun),\
|
side_effect=_fake_get_target_and_lun), \
|
||||||
mock.patch.object(self.target, '_get_target_chap_auth',
|
mock.patch.object(self.target, '_get_target_chap_auth',
|
||||||
side_effect=_fake_get_target_chap_auth),\
|
side_effect=_fake_get_target_chap_auth), \
|
||||||
mock.patch.object(self.target, 'initiator_iqn',
|
mock.patch.object(self.target, 'initiator_iqn',
|
||||||
return_value='iqn.1993-08.org.debian:'
|
return_value='iqn.1993-08.org.debian:'
|
||||||
'01:626bf14ebdc'),\
|
'01:626bf14ebdc'), \
|
||||||
mock.patch.object(self.target, '_iscsi_location',
|
mock.patch.object(self.target, '_iscsi_location',
|
||||||
side_effect=_fake_iscsi_location),\
|
side_effect=_fake_iscsi_location), \
|
||||||
mock.patch.object(self.target, 'target_driver',
|
mock.patch.object(self.target, 'target_driver',
|
||||||
return_value='iscsi'),\
|
return_value='iscsi'), \
|
||||||
mock.patch.object(volume_utils, 'generate_username',
|
mock.patch.object(volume_utils, 'generate_username',
|
||||||
side_effect=lambda: 'QZJbisGmn9AL954FNF4D'),\
|
side_effect=
|
||||||
|
lambda: 'QZJbisGmn9AL954FNF4D'), \
|
||||||
mock.patch.object(volume_utils, 'generate_password',
|
mock.patch.object(volume_utils, 'generate_password',
|
||||||
side_effect=lambda: 'P68eE7u9eFqDGexd28DQ'):
|
side_effect=lambda: 'P68eE7u9eFqDGexd28DQ'):
|
||||||
self.assertEqual(expected_result,
|
self.assertEqual(expected_result,
|
||||||
@ -189,9 +190,9 @@ class TestSCSTAdmDriver(tf.TargetDriverFixture):
|
|||||||
def _fake_get_target_chap_auth(*args, **kwargs):
|
def _fake_get_target_chap_auth(*args, **kwargs):
|
||||||
return ('QZJbisGmn9AL954FNF4D', 'P68eE7u9eFqDGexd28DQ')
|
return ('QZJbisGmn9AL954FNF4D', 'P68eE7u9eFqDGexd28DQ')
|
||||||
|
|
||||||
with mock.patch.object(self.target, 'create_iscsi_target'),\
|
with mock.patch.object(self.target, 'create_iscsi_target'), \
|
||||||
mock.patch.object(self.target, '_get_target_chap_auth',
|
mock.patch.object(self.target, '_get_target_chap_auth',
|
||||||
side_effect=_fake_get_target_chap_auth),\
|
side_effect=_fake_get_target_chap_auth), \
|
||||||
mock.patch.object(self.target, '_get_target_and_lun',
|
mock.patch.object(self.target, '_get_target_and_lun',
|
||||||
side_effect=_fake_get_target_and_lun):
|
side_effect=_fake_get_target_and_lun):
|
||||||
self.target.ensure_export(ctxt,
|
self.target.ensure_export(ctxt,
|
||||||
@ -219,9 +220,9 @@ class TestSCSTAdmDriver(tf.TargetDriverFixture):
|
|||||||
def _fake_get_target_chap_auth(*args, **kwargs):
|
def _fake_get_target_chap_auth(*args, **kwargs):
|
||||||
return None
|
return None
|
||||||
|
|
||||||
with mock.patch.object(self.target, 'create_iscsi_target'),\
|
with mock.patch.object(self.target, 'create_iscsi_target'), \
|
||||||
mock.patch.object(self.target, '_get_target_chap_auth',
|
mock.patch.object(self.target, '_get_target_chap_auth',
|
||||||
side_effect=_fake_get_target_chap_auth),\
|
side_effect=_fake_get_target_chap_auth), \
|
||||||
mock.patch.object(self.target, '_get_target_and_lun',
|
mock.patch.object(self.target, '_get_target_and_lun',
|
||||||
side_effect=_fake_get_target_and_lun):
|
side_effect=_fake_get_target_and_lun):
|
||||||
self.target.ensure_export(ctxt,
|
self.target.ensure_export(ctxt,
|
||||||
|
@ -142,9 +142,9 @@ class TestTgtAdmDriver(tf.TargetDriverFixture):
|
|||||||
@test.testtools.skipIf(sys.platform == "darwin", "SKIP on OSX")
|
@test.testtools.skipIf(sys.platform == "darwin", "SKIP on OSX")
|
||||||
def test_create_iscsi_target(self):
|
def test_create_iscsi_target(self):
|
||||||
with mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
with mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
||||||
return_value=('', '')),\
|
return_value=('', '')), \
|
||||||
mock.patch.object(self.target, '_get_target',
|
mock.patch.object(self.target, '_get_target',
|
||||||
side_effect=lambda x: 1),\
|
side_effect=lambda x: 1), \
|
||||||
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
||||||
return_value=('', '')), \
|
return_value=('', '')), \
|
||||||
mock.patch.object(self.target, '_verify_backing_lun',
|
mock.patch.object(self.target, '_verify_backing_lun',
|
||||||
@ -165,11 +165,11 @@ class TestTgtAdmDriver(tf.TargetDriverFixture):
|
|||||||
|
|
||||||
mock_open = mock.mock_open()
|
mock_open = mock.mock_open()
|
||||||
with mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
with mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
||||||
return_value=('', '')),\
|
return_value=('', '')), \
|
||||||
mock.patch.object(self.target, '_get_target',
|
mock.patch.object(self.target, '_get_target',
|
||||||
side_effect=lambda x: 1),\
|
side_effect=lambda x: 1), \
|
||||||
mock.patch.object(self.target, '_verify_backing_lun',
|
mock.patch.object(self.target, '_verify_backing_lun',
|
||||||
side_effect=lambda x, y: True),\
|
side_effect=lambda x, y: True), \
|
||||||
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
||||||
return_value=('', '')), \
|
return_value=('', '')), \
|
||||||
mock.patch('cinder.volume.targets.tgt.open',
|
mock.patch('cinder.volume.targets.tgt.open',
|
||||||
@ -196,9 +196,9 @@ class TestTgtAdmDriver(tf.TargetDriverFixture):
|
|||||||
return 'fake out', 'fake err'
|
return 'fake out', 'fake err'
|
||||||
|
|
||||||
with mock.patch.object(self.target, '_get_target',
|
with mock.patch.object(self.target, '_get_target',
|
||||||
side_effect=lambda x: 1),\
|
side_effect=lambda x: 1), \
|
||||||
mock.patch.object(self.target, '_verify_backing_lun',
|
mock.patch.object(self.target, '_verify_backing_lun',
|
||||||
side_effect=lambda x, y: True),\
|
side_effect=lambda x, y: True), \
|
||||||
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
||||||
return_value=('', '')), \
|
return_value=('', '')), \
|
||||||
mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
||||||
@ -344,15 +344,15 @@ class TestTgtAdmDriver(tf.TargetDriverFixture):
|
|||||||
'auth': 'CHAP QZJb P68e'}
|
'auth': 'CHAP QZJb P68e'}
|
||||||
|
|
||||||
with mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
with mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
||||||
return_value=('', '')),\
|
return_value=('', '')), \
|
||||||
mock.patch.object(self.target, '_get_target',
|
mock.patch.object(self.target, '_get_target',
|
||||||
side_effect=lambda x: 1),\
|
side_effect=lambda x: 1), \
|
||||||
mock.patch.object(self.target, '_verify_backing_lun',
|
mock.patch.object(self.target, '_verify_backing_lun',
|
||||||
side_effect=lambda x, y: True),\
|
side_effect=lambda x, y: True), \
|
||||||
mock.patch.object(self.target, '_get_target_chap_auth',
|
mock.patch.object(self.target, '_get_target_chap_auth',
|
||||||
side_effect=lambda x, y: None) as m_chap,\
|
side_effect=lambda x, y: None) as m_chap, \
|
||||||
mock.patch.object(volume_utils, 'generate_username',
|
mock.patch.object(volume_utils, 'generate_username',
|
||||||
side_effect=lambda: 'QZJb'),\
|
side_effect=lambda: 'QZJb'), \
|
||||||
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
||||||
return_value=('', '')), \
|
return_value=('', '')), \
|
||||||
mock.patch.object(volume_utils, 'generate_password',
|
mock.patch.object(volume_utils, 'generate_password',
|
||||||
@ -393,9 +393,9 @@ class TestTgtAdmDriver(tf.TargetDriverFixture):
|
|||||||
@test.testtools.skipIf(sys.platform == "darwin", "SKIP on OSX")
|
@test.testtools.skipIf(sys.platform == "darwin", "SKIP on OSX")
|
||||||
def test_create_iscsi_target_retry(self):
|
def test_create_iscsi_target_retry(self):
|
||||||
with mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
with mock.patch('cinder.privsep.targets.tgt.tgtadm_show',
|
||||||
return_value=('', '')),\
|
return_value=('', '')), \
|
||||||
mock.patch.object(self.target, '_get_target',
|
mock.patch.object(self.target, '_get_target',
|
||||||
side_effect=[None, None, 1]) as get_target,\
|
side_effect=[None, None, 1]) as get_target, \
|
||||||
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
mock.patch('cinder.privsep.targets.tgt.tgtadmin_update',
|
||||||
return_value=('', '')), \
|
return_value=('', '')), \
|
||||||
mock.patch.object(self.target, '_verify_backing_lun',
|
mock.patch.object(self.target, '_verify_backing_lun',
|
||||||
|
@ -135,7 +135,7 @@ class TestCleanableManager(test.TestCase):
|
|||||||
|
|
||||||
clean_req = objects.CleanupRequest(service_id=self.service.id)
|
clean_req = objects.CleanupRequest(service_id=self.service.id)
|
||||||
mngr = FakeManager(self.service.id)
|
mngr = FakeManager(self.service.id)
|
||||||
with mock.patch('cinder.manager.timeutils.utcnow', return_value=now),\
|
with mock.patch('cinder.manager.timeutils.utcnow', return_value=now), \
|
||||||
mock.patch('cinder.db.worker_get_all') as get_all_mock:
|
mock.patch('cinder.db.worker_get_all') as get_all_mock:
|
||||||
get_all_mock.return_value = [worker1, worker2]
|
get_all_mock.return_value = [worker1, worker2]
|
||||||
mngr.do_cleanup(self.context, clean_req)
|
mngr.do_cleanup(self.context, clean_req)
|
||||||
|
@ -2001,7 +2001,7 @@ class TestHPE3PARDriverBase(HPE3PARBaseDriver):
|
|||||||
VOLUME_INFO_0 = self.RETYPE_VOLUME_INFO_0.copy()
|
VOLUME_INFO_0 = self.RETYPE_VOLUME_INFO_0.copy()
|
||||||
|
|
||||||
# volume without comment
|
# volume without comment
|
||||||
del(VOLUME_INFO_0['comment'])
|
del (VOLUME_INFO_0['comment'])
|
||||||
mock_client.getVolume.return_value = VOLUME_INFO_0
|
mock_client.getVolume.return_value = VOLUME_INFO_0
|
||||||
|
|
||||||
with mock.patch.object(hpecommon.HPE3PARCommon,
|
with mock.patch.object(hpecommon.HPE3PARCommon,
|
||||||
|
@ -9187,7 +9187,7 @@ class StorwizeSVCCommonDriverTestCase(test.TestCase):
|
|||||||
host='openstack@svc#hyperswap1',
|
host='openstack@svc#hyperswap1',
|
||||||
volume_type_id=hyper_type.id)
|
volume_type_id=hyper_type.id)
|
||||||
with (mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
with (mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
'convert_volume_to_hyperswap')) as convert_volume_to_hyperswap,\
|
'convert_volume_to_hyperswap')) as convert_volume_to_hyperswap, \
|
||||||
(mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
(mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
'ensure_vdisk_no_fc_mappings')) as ensure_vdisk_no_fc_mappings:
|
'ensure_vdisk_no_fc_mappings')) as ensure_vdisk_no_fc_mappings:
|
||||||
self.driver.create_volume_from_snapshot(vol2, snap)
|
self.driver.create_volume_from_snapshot(vol2, snap)
|
||||||
@ -10063,7 +10063,7 @@ class StorwizeSVCCommonDriverTestCase(test.TestCase):
|
|||||||
[clone_vol1, clone_vol2])
|
[clone_vol1, clone_vol2])
|
||||||
|
|
||||||
with (mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
with (mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
'convert_volume_to_hyperswap')) as convert_volume_to_hyperswap,\
|
'convert_volume_to_hyperswap')) as convert_volume_to_hyperswap, \
|
||||||
(mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
(mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
'ensure_vdisk_no_fc_mappings')) as ensure_vdisk_no_fc_mappings:
|
'ensure_vdisk_no_fc_mappings')) as ensure_vdisk_no_fc_mappings:
|
||||||
|
|
||||||
@ -10189,7 +10189,7 @@ class StorwizeSVCCommonDriverTestCase(test.TestCase):
|
|||||||
[clone_vol1, clone_vol2])
|
[clone_vol1, clone_vol2])
|
||||||
|
|
||||||
with (mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
with (mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
'convert_volume_to_hyperswap')) as convert_volume_to_hyperswap,\
|
'convert_volume_to_hyperswap')) as convert_volume_to_hyperswap, \
|
||||||
(mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
(mock.patch.object(storwize_svc_common.StorwizeHelpers,
|
||||||
'ensure_vdisk_no_fc_mappings')) as ensure_vdisk_no_fc_mappings:
|
'ensure_vdisk_no_fc_mappings')) as ensure_vdisk_no_fc_mappings:
|
||||||
|
|
||||||
@ -11470,7 +11470,7 @@ class StorwizeSSHTestCase(test.TestCase):
|
|||||||
opt = {'iogrp': 0}
|
opt = {'iogrp': 0}
|
||||||
with mock.patch.object(storwize_svc_common.StorwizeSSH,
|
with mock.patch.object(storwize_svc_common.StorwizeSSH,
|
||||||
'run_ssh_check_created',
|
'run_ssh_check_created',
|
||||||
side_effect=run_ssh_check),\
|
side_effect=run_ssh_check), \
|
||||||
mock.patch.object(storwize_svc_common.StorwizeSSH, 'lsvdisk',
|
mock.patch.object(storwize_svc_common.StorwizeSSH, 'lsvdisk',
|
||||||
return_value=lsvol):
|
return_value=lsvol):
|
||||||
if lsvol:
|
if lsvol:
|
||||||
|
@ -890,8 +890,8 @@ class AS13000DriverTestCase(test.TestCase):
|
|||||||
mock_tnd = self.mock_object(self.as13000_san, '_trans_name_down',
|
mock_tnd = self.mock_object(self.as13000_san, '_trans_name_down',
|
||||||
mock.Mock(return_value='fake_volume'))
|
mock.Mock(return_value='fake_volume'))
|
||||||
fake_target_list = [{'hostIp': ['fake_hostIp'],
|
fake_target_list = [{'hostIp': ['fake_hostIp'],
|
||||||
'name':'target_name',
|
'name': 'target_name',
|
||||||
'lun':[{'lvm': 'fake_volume',
|
'lun': [{'lvm': 'fake_volume',
|
||||||
'lunID': 'fake_id'}]}]
|
'lunID': 'fake_id'}]}]
|
||||||
mock_gtl = self.mock_object(self.as13000_san, '_get_target_list',
|
mock_gtl = self.mock_object(self.as13000_san, '_get_target_list',
|
||||||
mock.Mock(return_value=fake_target_list))
|
mock.Mock(return_value=fake_target_list))
|
||||||
@ -978,8 +978,8 @@ class AS13000DriverTestCase(test.TestCase):
|
|||||||
target_list = [
|
target_list = [
|
||||||
{
|
{
|
||||||
'hostIp': ['fake_ip1', 'fake_ip2'],
|
'hostIp': ['fake_ip1', 'fake_ip2'],
|
||||||
'name':'fake_target_1',
|
'name': 'fake_target_1',
|
||||||
'node':['fake_node1', 'fake_node2']
|
'node': ['fake_node1', 'fake_node2']
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'hostIp': ['fake_ip3', 'fake_ip4'],
|
'hostIp': ['fake_ip3', 'fake_ip4'],
|
||||||
|
@ -1522,7 +1522,7 @@ class TestOpenEJovianDSSDriver(test.TestCase):
|
|||||||
|
|
||||||
get_vol['volsize'] = "1073145824"
|
get_vol['volsize'] = "1073145824"
|
||||||
jdssd.ra.get_lun.return_value = get_vol
|
jdssd.ra.get_lun.return_value = get_vol
|
||||||
with mock.patch.object(jdssd, '_clone_object'),\
|
with mock.patch.object(jdssd, '_clone_object'), \
|
||||||
mock.patch.object(jdssd, "resize_volume"):
|
mock.patch.object(jdssd, "resize_volume"):
|
||||||
jdssd.create_cloned_volume(UUID_2, UUID_1, 1, sparse=False)
|
jdssd.create_cloned_volume(UUID_2, UUID_1, 1, sparse=False)
|
||||||
|
|
||||||
|
@ -589,9 +589,9 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
'_get_sfaccounts_for_tenant',
|
'_get_sfaccounts_for_tenant',
|
||||||
return_value=[{'accountID': 5,
|
return_value=[{'accountID': 5,
|
||||||
'username':
|
'username':
|
||||||
'prefix-testprjid'}]),\
|
'prefix-testprjid'}]), \
|
||||||
mock.patch.object(sfv, '_retrieve_replication_settings',
|
mock.patch.object(sfv, '_retrieve_replication_settings',
|
||||||
return_value=["Async", {}]),\
|
return_value=["Async", {}]), \
|
||||||
mock.patch.object(sfv, '_get_sf_volume',
|
mock.patch.object(sfv, '_get_sf_volume',
|
||||||
return_value={'volumeID': 33}):
|
return_value={'volumeID': 33}):
|
||||||
sfv.create_snapshot(testsnap)
|
sfv.create_snapshot(testsnap)
|
||||||
@ -2369,7 +2369,7 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
{'name': prefix + 'three'}]
|
{'name': prefix + 'three'}]
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_get_all_active_volumes',
|
'_get_all_active_volumes',
|
||||||
return_value=active_vols),\
|
return_value=active_vols), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_sf_create_group_snapshot',
|
'_sf_create_group_snapshot',
|
||||||
return_value=None) as create:
|
return_value=None) as create:
|
||||||
@ -2439,7 +2439,7 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
fake_gsnap = {'groupSnapshotID': 42}
|
fake_gsnap = {'groupSnapshotID': 42}
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_get_group_snapshot_by_name',
|
'_get_group_snapshot_by_name',
|
||||||
return_value=fake_gsnap),\
|
return_value=fake_gsnap), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_delete_group_snapshot') as del_stuff:
|
'_delete_group_snapshot') as del_stuff:
|
||||||
sfv._delete_cgsnapshot_by_name('does not matter')
|
sfv._delete_cgsnapshot_by_name('does not matter')
|
||||||
@ -2480,9 +2480,9 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
kek = (None, None, {})
|
kek = (None, None, {})
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_get_group_snapshot_by_name',
|
'_get_group_snapshot_by_name',
|
||||||
return_value=group_snap) as get_snap,\
|
return_value=group_snap) as get_snap, \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_find_linked_snapshot'),\
|
'_find_linked_snapshot'), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_do_clone_volume',
|
'_do_clone_volume',
|
||||||
return_value=kek):
|
return_value=kek):
|
||||||
@ -2510,16 +2510,16 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
kek = (None, None, {})
|
kek = (None, None, {})
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_create_temp_group_snapshot',
|
'_create_temp_group_snapshot',
|
||||||
return_value=source_cg['id']),\
|
return_value=source_cg['id']), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_get_group_snapshot_by_name',
|
'_get_group_snapshot_by_name',
|
||||||
return_value=group_snap) as get_snap,\
|
return_value=group_snap) as get_snap, \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_find_linked_snapshot',
|
'_find_linked_snapshot',
|
||||||
return_value=source_snap),\
|
return_value=source_snap), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_do_clone_volume',
|
'_do_clone_volume',
|
||||||
return_value=kek),\
|
return_value=kek), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_delete_cgsnapshot_by_name'):
|
'_delete_cgsnapshot_by_name'):
|
||||||
model, vol_models = sfv._create_consistencygroup_from_src(
|
model, vol_models = sfv._create_consistencygroup_from_src(
|
||||||
@ -2542,7 +2542,7 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
{'name': pfx + 'two'}]
|
{'name': pfx + 'two'}]
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_get_all_active_volumes',
|
'_get_all_active_volumes',
|
||||||
return_value=active_vols),\
|
return_value=active_vols), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_sf_create_group_snapshot') as create_gsnap:
|
'_sf_create_group_snapshot') as create_gsnap:
|
||||||
sfv._create_cgsnapshot(ctxt, cgsnapshot, snapshots)
|
sfv._create_cgsnapshot(ctxt, cgsnapshot, snapshots)
|
||||||
@ -2559,7 +2559,7 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
active_vols = [{'name': pfx + 'one'}]
|
active_vols = [{'name': pfx + 'one'}]
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_get_all_active_volumes',
|
'_get_all_active_volumes',
|
||||||
return_value=active_vols),\
|
return_value=active_vols), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_sf_create_group_snapshot'):
|
'_sf_create_group_snapshot'):
|
||||||
self.assertRaises(solidfire.SolidFireDriverException,
|
self.assertRaises(solidfire.SolidFireDriverException,
|
||||||
@ -2579,7 +2579,7 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
source.get('group_snapshot_id'))
|
source.get('group_snapshot_id'))
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_get_group_snapshot_by_name',
|
'_get_group_snapshot_by_name',
|
||||||
return_value={}) as get,\
|
return_value={}) as get, \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_create_clone_from_sf_snapshot',
|
'_create_clone_from_sf_snapshot',
|
||||||
return_value='model'):
|
return_value='model'):
|
||||||
@ -2787,10 +2787,10 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
|
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_issue_api_request',
|
'_issue_api_request',
|
||||||
self.fake_issue_api_request),\
|
self.fake_issue_api_request), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_get_sfaccount_by_name',
|
'_get_sfaccount_by_name',
|
||||||
return_value={'accountID': 1}),\
|
return_value={'accountID': 1}), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_do_volume_create',
|
'_do_volume_create',
|
||||||
return_value=model_update):
|
return_value=model_update):
|
||||||
@ -2806,13 +2806,13 @@ class SolidFireVolumeTestCase(test.TestCase):
|
|||||||
sfv = solidfire.SolidFireDriver(configuration=self.configuration)
|
sfv = solidfire.SolidFireDriver(configuration=self.configuration)
|
||||||
with mock.patch.object(sfv,
|
with mock.patch.object(sfv,
|
||||||
'_get_create_account',
|
'_get_create_account',
|
||||||
return_value={'accountID': 5}),\
|
return_value={'accountID': 5}), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_retrieve_qos_setting',
|
'_retrieve_qos_setting',
|
||||||
return_value=None), \
|
return_value=None), \
|
||||||
mock.patch.object(sfv,
|
mock.patch.object(sfv,
|
||||||
'_do_volume_create',
|
'_do_volume_create',
|
||||||
return_value={'provider_id': '1 2 xxxx'}),\
|
return_value={'provider_id': '1 2 xxxx'}), \
|
||||||
mock.patch.object(volume_types,
|
mock.patch.object(volume_types,
|
||||||
'get_volume_type',
|
'get_volume_type',
|
||||||
return_value=fake_type), \
|
return_value=fake_type), \
|
||||||
|
@ -784,20 +784,20 @@ class LVMVolumeDriverTestCase(test_driver.BaseDriverTestCase):
|
|||||||
self.context, fake_volume.id)
|
self.context, fake_volume.id)
|
||||||
|
|
||||||
with mock.patch.object(self.volume.driver.vg,
|
with mock.patch.object(self.volume.driver.vg,
|
||||||
'revert') as mock_revert,\
|
'revert') as mock_revert, \
|
||||||
mock.patch.object(self.volume.driver.vg,
|
mock.patch.object(self.volume.driver.vg,
|
||||||
'create_lv_snapshot') as mock_create,\
|
'create_lv_snapshot') as mock_create, \
|
||||||
mock.patch.object(self.volume.driver.vg,
|
mock.patch.object(self.volume.driver.vg,
|
||||||
'deactivate_lv') as mock_deactive,\
|
'deactivate_lv') as mock_deactivate, \
|
||||||
mock.patch.object(self.volume.driver.vg,
|
mock.patch.object(self.volume.driver.vg,
|
||||||
'activate_lv') as mock_active:
|
'activate_lv') as mock_activate:
|
||||||
self.volume.driver.revert_to_snapshot(self.context,
|
self.volume.driver.revert_to_snapshot(self.context,
|
||||||
fake_volume,
|
fake_volume,
|
||||||
fake_snapshot)
|
fake_snapshot)
|
||||||
mock_revert.assert_called_once_with(
|
mock_revert.assert_called_once_with(
|
||||||
self.volume.driver._escape_snapshot(fake_snapshot.name))
|
self.volume.driver._escape_snapshot(fake_snapshot.name))
|
||||||
mock_deactive.assert_called_once_with(fake_volume.name)
|
mock_deactivate.assert_called_once_with(fake_volume.name)
|
||||||
mock_active.assert_called_once_with(fake_volume.name)
|
mock_activate.assert_called_once_with(fake_volume.name)
|
||||||
mock_create.assert_called_once_with(
|
mock_create.assert_called_once_with(
|
||||||
self.volume.driver._escape_snapshot(fake_snapshot.name),
|
self.volume.driver._escape_snapshot(fake_snapshot.name),
|
||||||
fake_volume.name, self.configuration.lvm_type)
|
fake_volume.name, self.configuration.lvm_type)
|
||||||
|
@ -327,7 +327,7 @@ class TestSeagateClient(test.TestCase):
|
|||||||
RequestException("error")]
|
RequestException("error")]
|
||||||
mock_requests_get.return_value = m
|
mock_requests_get.return_value = m
|
||||||
ret = self.client._api_request('/path')
|
ret = self.client._api_request('/path')
|
||||||
self.assertTrue(type(ret) == etree._Element)
|
self.assertTrue(type(ret) is etree._Element)
|
||||||
self.assertRaises(stx_exception.ConnectionError,
|
self.assertRaises(stx_exception.ConnectionError,
|
||||||
self.client._api_request,
|
self.client._api_request,
|
||||||
'/path')
|
'/path')
|
||||||
|
@ -244,8 +244,8 @@ class SnapshotTestCase(base.BaseVolumeTestCase):
|
|||||||
mock_get.return_value = test_volume
|
mock_get.return_value = test_volume
|
||||||
volume_api = cinder.volume.api.API()
|
volume_api = cinder.volume.api.API()
|
||||||
|
|
||||||
with mock.patch.object(QUOTAS, 'add_volume_type_opts'),\
|
with mock.patch.object(QUOTAS, 'add_volume_type_opts'), \
|
||||||
mock.patch.object(QUOTAS, 'reserve') as mock_reserve,\
|
mock.patch.object(QUOTAS, 'reserve') as mock_reserve, \
|
||||||
mock.patch.object(QUOTAS, 'commit') as mock_commit:
|
mock.patch.object(QUOTAS, 'commit') as mock_commit:
|
||||||
self.assertRaises(exception.InvalidInput,
|
self.assertRaises(exception.InvalidInput,
|
||||||
volume_api.create_snapshot_in_db,
|
volume_api.create_snapshot_in_db,
|
||||||
|
@ -2253,9 +2253,9 @@ class VolumeTestCase(base.BaseVolumeTestCase):
|
|||||||
fake_volume.id)
|
fake_volume.id)
|
||||||
with mock.patch.object(
|
with mock.patch.object(
|
||||||
self.volume.driver,
|
self.volume.driver,
|
||||||
'_create_temp_volume_from_snapshot') as mock_temp,\
|
'_create_temp_volume_from_snapshot') as mock_temp, \
|
||||||
mock.patch.object(
|
mock.patch.object(
|
||||||
self.volume.driver, 'delete_volume') as mock_driver_delete,\
|
self.volume.driver, 'delete_volume') as mock_driver_delete, \
|
||||||
mock.patch.object(
|
mock.patch.object(
|
||||||
self.volume, '_copy_volume_data') as mock_copy:
|
self.volume, '_copy_volume_data') as mock_copy:
|
||||||
temp_volume = tests_utils.create_volume(self.context,
|
temp_volume = tests_utils.create_volume(self.context,
|
||||||
@ -2277,7 +2277,7 @@ class VolumeTestCase(base.BaseVolumeTestCase):
|
|||||||
with mock.patch.object(self.volume.driver,
|
with mock.patch.object(self.volume.driver,
|
||||||
'revert_to_snapshot') as driver_revert, \
|
'revert_to_snapshot') as driver_revert, \
|
||||||
mock.patch.object(self.volume, '_notify_about_volume_usage'), \
|
mock.patch.object(self.volume, '_notify_about_volume_usage'), \
|
||||||
mock.patch.object(self.volume, '_notify_about_snapshot_usage'),\
|
mock.patch.object(self.volume, '_notify_about_snapshot_usage'), \
|
||||||
mock.patch.object(self.volume,
|
mock.patch.object(self.volume,
|
||||||
'_revert_to_snapshot_generic') as generic_revert:
|
'_revert_to_snapshot_generic') as generic_revert:
|
||||||
if driver_error:
|
if driver_error:
|
||||||
@ -2307,9 +2307,9 @@ class VolumeTestCase(base.BaseVolumeTestCase):
|
|||||||
status='restoring',
|
status='restoring',
|
||||||
volume_size=1)
|
volume_size=1)
|
||||||
with mock.patch.object(self.volume,
|
with mock.patch.object(self.volume,
|
||||||
'_revert_to_snapshot') as _revert,\
|
'_revert_to_snapshot') as _revert, \
|
||||||
mock.patch.object(self.volume,
|
mock.patch.object(self.volume,
|
||||||
'_create_backup_snapshot') as _create_snapshot,\
|
'_create_backup_snapshot') as _create_snapshot, \
|
||||||
mock.patch.object(self.volume,
|
mock.patch.object(self.volume,
|
||||||
'delete_snapshot') as _delete_snapshot, \
|
'delete_snapshot') as _delete_snapshot, \
|
||||||
mock.patch.object(self.volume.driver,
|
mock.patch.object(self.volume.driver,
|
||||||
|
@ -134,7 +134,7 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
|
|
||||||
def test_migrate_volume_error(self):
|
def test_migrate_volume_error(self):
|
||||||
with mock.patch.object(self.volume.driver, 'migrate_volume') as \
|
with mock.patch.object(self.volume.driver, 'migrate_volume') as \
|
||||||
mock_migrate,\
|
mock_migrate, \
|
||||||
mock.patch.object(self.volume.driver, 'create_export') as \
|
mock.patch.object(self.volume.driver, 'create_export') as \
|
||||||
mock_create_export:
|
mock_create_export:
|
||||||
|
|
||||||
@ -338,8 +338,8 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
|
|
||||||
host_obj = {'host': 'newhost', 'capabilities': {}}
|
host_obj = {'host': 'newhost', 'capabilities': {}}
|
||||||
with mock.patch.object(self.volume.driver, 'migrate_volume') as \
|
with mock.patch.object(self.volume.driver, 'migrate_volume') as \
|
||||||
mock_migrate_volume,\
|
mock_migrate_volume, \
|
||||||
mock.patch.object(self.volume, '_copy_volume_data'),\
|
mock.patch.object(self.volume, '_copy_volume_data'), \
|
||||||
mock.patch.object(self.volume.driver, 'delete_volume') as \
|
mock.patch.object(self.volume.driver, 'delete_volume') as \
|
||||||
delete_volume:
|
delete_volume:
|
||||||
create_volume.side_effect = self._fake_create_volume
|
create_volume.side_effect = self._fake_create_volume
|
||||||
@ -355,13 +355,13 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
self.assertTrue(update_migrated_volume.called)
|
self.assertTrue(update_migrated_volume.called)
|
||||||
|
|
||||||
def test_migrate_volume_generic_copy_error(self):
|
def test_migrate_volume_generic_copy_error(self):
|
||||||
with mock.patch.object(self.volume.driver, 'migrate_volume'),\
|
with mock.patch.object(self.volume.driver, 'migrate_volume'), \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI, 'create_volume')\
|
mock.patch.object(volume_rpcapi.VolumeAPI, 'create_volume') \
|
||||||
as mock_create_volume,\
|
as mock_create_volume, \
|
||||||
mock.patch.object(self.volume, '_copy_volume_data') as \
|
mock.patch.object(self.volume, '_copy_volume_data') as \
|
||||||
mock_copy_volume,\
|
mock_copy_volume, \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI, 'delete_volume'),\
|
mock.patch.object(volume_rpcapi.VolumeAPI, 'delete_volume'), \
|
||||||
mock.patch.object(self.volume, 'migrate_volume_completion'),\
|
mock.patch.object(self.volume, 'migrate_volume_completion'), \
|
||||||
mock.patch.object(self.volume.driver, 'create_export'):
|
mock.patch.object(self.volume.driver, 'create_export'):
|
||||||
|
|
||||||
# Exception case at migrate_volume_generic
|
# Exception case at migrate_volume_generic
|
||||||
@ -434,7 +434,7 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
expected_update = {'_name_id': volume._name_id,
|
expected_update = {'_name_id': volume._name_id,
|
||||||
'provider_location': volume.provider_location}
|
'provider_location': volume.provider_location}
|
||||||
with mock.patch.object(self.volume.driver,
|
with mock.patch.object(self.volume.driver,
|
||||||
'update_migrated_volume') as migrate_update,\
|
'update_migrated_volume') as migrate_update, \
|
||||||
mock.patch.object(self.context, 'elevated') as elevated:
|
mock.patch.object(self.context, 'elevated') as elevated:
|
||||||
migrate_update.return_value = fake_update
|
migrate_update.return_value = fake_update
|
||||||
elevated.return_value = fake_elevated
|
elevated.return_value = fake_elevated
|
||||||
@ -516,13 +516,13 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
self.expected_status = 'available'
|
self.expected_status = 'available'
|
||||||
|
|
||||||
def test_migrate_volume_generic_create_export_error(self):
|
def test_migrate_volume_generic_create_export_error(self):
|
||||||
with mock.patch.object(self.volume.driver, 'migrate_volume'),\
|
with mock.patch.object(self.volume.driver, 'migrate_volume'), \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI, 'create_volume')\
|
mock.patch.object(volume_rpcapi.VolumeAPI, 'create_volume') \
|
||||||
as mock_create_volume,\
|
as mock_create_volume, \
|
||||||
mock.patch.object(self.volume, '_copy_volume_data') as \
|
mock.patch.object(self.volume, '_copy_volume_data') as \
|
||||||
mock_copy_volume,\
|
mock_copy_volume, \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI, 'delete_volume'),\
|
mock.patch.object(volume_rpcapi.VolumeAPI, 'delete_volume'), \
|
||||||
mock.patch.object(self.volume, 'migrate_volume_completion'),\
|
mock.patch.object(self.volume, 'migrate_volume_completion'), \
|
||||||
mock.patch.object(self.volume.driver, 'create_export') as \
|
mock.patch.object(self.volume.driver, 'create_export') as \
|
||||||
mock_create_export:
|
mock_create_export:
|
||||||
|
|
||||||
@ -551,12 +551,12 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
{'migration_status': 'completing'})
|
{'migration_status': 'completing'})
|
||||||
raise processutils.ProcessExecutionError
|
raise processutils.ProcessExecutionError
|
||||||
|
|
||||||
with mock.patch.object(self.volume.driver, 'migrate_volume'),\
|
with mock.patch.object(self.volume.driver, 'migrate_volume'), \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI, 'create_volume')\
|
mock.patch.object(volume_rpcapi.VolumeAPI, 'create_volume')\
|
||||||
as mock_create_volume,\
|
as mock_create_volume, \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI, 'delete_volume'),\
|
mock.patch.object(volume_rpcapi.VolumeAPI, 'delete_volume'), \
|
||||||
mock.patch.object(self.volume, 'migrate_volume_completion')\
|
mock.patch.object(self.volume, 'migrate_volume_completion')\
|
||||||
as mock_migrate_compl,\
|
as mock_migrate_compl, \
|
||||||
mock.patch.object(self.volume.driver, 'create_export'), \
|
mock.patch.object(self.volume.driver, 'create_export'), \
|
||||||
mock.patch.object(self.volume, '_attach_volume') \
|
mock.patch.object(self.volume, '_attach_volume') \
|
||||||
as mock_attach, \
|
as mock_attach, \
|
||||||
@ -623,11 +623,11 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
host=new_host,
|
host=new_host,
|
||||||
migration_status=target_status)
|
migration_status=target_status)
|
||||||
with mock.patch.object(self.volume, 'detach_volume') as \
|
with mock.patch.object(self.volume, 'detach_volume') as \
|
||||||
mock_detach_volume,\
|
mock_detach_volume, \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI,
|
mock.patch.object(volume_rpcapi.VolumeAPI,
|
||||||
'delete_volume') as mock_delete_volume,\
|
'delete_volume') as mock_delete_volume, \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI,
|
mock.patch.object(volume_rpcapi.VolumeAPI,
|
||||||
'attach_volume') as mock_attach_volume,\
|
'attach_volume') as mock_attach_volume, \
|
||||||
mock.patch.object(volume_rpcapi.VolumeAPI,
|
mock.patch.object(volume_rpcapi.VolumeAPI,
|
||||||
'update_migrated_volume'):
|
'update_migrated_volume'):
|
||||||
mock_attach_volume.side_effect = self.fake_attach_volume
|
mock_attach_volume.side_effect = self.fake_attach_volume
|
||||||
@ -810,11 +810,13 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
|
|
||||||
old_usage = db.quota_usage_get_all_by_project(elevated, project_id)
|
old_usage = db.quota_usage_get_all_by_project(elevated, project_id)
|
||||||
|
|
||||||
with mock.patch.object(self.volume.driver, 'retype') as _retype,\
|
with mock.patch.object(self.volume.driver, 'retype') as _retype, \
|
||||||
mock.patch.object(volume_types, 'volume_types_diff') as _diff,\
|
mock.patch.object(volume_types,
|
||||||
mock.patch.object(self.volume, 'migrate_volume') as _mig,\
|
'volume_types_diff') as _diff, \
|
||||||
mock.patch.object(db.sqlalchemy.api, 'volume_get') as _vget,\
|
mock.patch.object(self.volume, 'migrate_volume') as _mig, \
|
||||||
mock.patch.object(context.RequestContext, 'elevated') as _ctx,\
|
mock.patch.object(db.sqlalchemy.api, 'volume_get') as _vget, \
|
||||||
|
mock.patch.object(context.RequestContext,
|
||||||
|
'elevated') as _ctx, \
|
||||||
mock.patch.object(objects.VolumeType, 'get_by_id') as _vtget:
|
mock.patch.object(objects.VolumeType, 'get_by_id') as _vtget:
|
||||||
_vget.return_value = volume
|
_vget.return_value = volume
|
||||||
_retype.return_value = driver
|
_retype.return_value = driver
|
||||||
@ -1014,7 +1016,7 @@ class VolumeMigrationTestCase(base.BaseVolumeTestCase):
|
|||||||
replication_status='not-capable')
|
replication_status='not-capable')
|
||||||
host_obj = {'host': 'newhost', 'capabilities': {}}
|
host_obj = {'host': 'newhost', 'capabilities': {}}
|
||||||
with mock.patch.object(self.volume,
|
with mock.patch.object(self.volume,
|
||||||
'migrate_volume') as migrate_volume,\
|
'migrate_volume') as migrate_volume, \
|
||||||
mock.patch.object(objects.VolumeType,
|
mock.patch.object(objects.VolumeType,
|
||||||
'get_by_id') as vt_get:
|
'get_by_id') as vt_get:
|
||||||
migrate_volume.return_value = True
|
migrate_volume.return_value = True
|
||||||
|
@ -795,7 +795,7 @@ class ApiClient(object):
|
|||||||
if data is None:
|
if data is None:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
if type(klass) == str:
|
if type(klass) is str:
|
||||||
if klass.startswith('list['):
|
if klass.startswith('list['):
|
||||||
sub_kls = re.match(r'list\[(.*)\]', klass).group(1)
|
sub_kls = re.match(r'list\[(.*)\]', klass).group(1)
|
||||||
return [self.__deserialize(sub_data, sub_kls)
|
return [self.__deserialize(sub_data, sub_kls)
|
||||||
|
@ -1594,7 +1594,7 @@ class NimbleRestAPIExecutor(object):
|
|||||||
LOG.debug("Key %(key)s Value %(value)s",
|
LOG.debug("Key %(key)s Value %(value)s",
|
||||||
{'key': key, 'value': value})
|
{'key': key, 'value': value})
|
||||||
if key == EXTRA_SPEC_IOPS_LIMIT and value.isdigit():
|
if key == EXTRA_SPEC_IOPS_LIMIT and value.isdigit():
|
||||||
if type(value) == int or int(value) < MIN_IOPS or (
|
if type(value) is int or int(value) < MIN_IOPS or (
|
||||||
int(value) > MAX_IOPS):
|
int(value) > MAX_IOPS):
|
||||||
raise NimbleAPIException(_("%(err)s [%(min)s, %(max)s]") %
|
raise NimbleAPIException(_("%(err)s [%(min)s, %(max)s]") %
|
||||||
{'err': IOPS_ERR_MSG,
|
{'err': IOPS_ERR_MSG,
|
||||||
@ -2066,7 +2066,7 @@ class NimbleRestAPIExecutor(object):
|
|||||||
LOG.debug("Key %(key)s Value %(value)s",
|
LOG.debug("Key %(key)s Value %(value)s",
|
||||||
{'key': key, 'value': value})
|
{'key': key, 'value': value})
|
||||||
if key == EXTRA_SPEC_IOPS_LIMIT and value.isdigit():
|
if key == EXTRA_SPEC_IOPS_LIMIT and value.isdigit():
|
||||||
if type(value) == int or int(value) < MIN_IOPS or (
|
if type(value) is int or int(value) < MIN_IOPS or (
|
||||||
int(value) > MAX_IOPS):
|
int(value) > MAX_IOPS):
|
||||||
raise NimbleAPIException(_("Please enter valid IOPS "
|
raise NimbleAPIException(_("Please enter valid IOPS "
|
||||||
"limit in the range ["
|
"limit in the range ["
|
||||||
|
@ -53,7 +53,7 @@ class STXFCDriver(cinder.volume.driver.FibreChannelDriver):
|
|||||||
self.common = None
|
self.common = None
|
||||||
self.configuration.append_config_values(san.san_opts)
|
self.configuration.append_config_values(san.san_opts)
|
||||||
self.lookup_service = fczm_utils.create_lookup_service()
|
self.lookup_service = fczm_utils.create_lookup_service()
|
||||||
if type(self) != STXFCDriver:
|
if type(self) is not STXFCDriver:
|
||||||
return
|
return
|
||||||
self.configuration.append_config_values(common.common_opts)
|
self.configuration.append_config_values(common.common_opts)
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ class STXISCSIDriver(cinder.volume.driver.ISCSIDriver):
|
|||||||
super(STXISCSIDriver, self).__init__(*args, **kwargs)
|
super(STXISCSIDriver, self).__init__(*args, **kwargs)
|
||||||
self.common = None
|
self.common = None
|
||||||
self.configuration.append_config_values(san.san_opts)
|
self.configuration.append_config_values(san.san_opts)
|
||||||
if type(self) != STXISCSIDriver:
|
if type(self) is not STXISCSIDriver:
|
||||||
return
|
return
|
||||||
self.configuration.append_config_values(common.common_opts)
|
self.configuration.append_config_values(common.common_opts)
|
||||||
self.configuration.append_config_values(common.iscsi_opts)
|
self.configuration.append_config_values(common.iscsi_opts)
|
||||||
@ -154,7 +154,7 @@ class STXISCSIDriver(cinder.volume.driver.ISCSIDriver):
|
|||||||
self.common.client_logout()
|
self.common.client_logout()
|
||||||
|
|
||||||
def terminate_connection(self, volume, connector, **kwargs):
|
def terminate_connection(self, volume, connector, **kwargs):
|
||||||
if type(connector) == dict and 'initiator' in connector:
|
if type(connector) is dict and 'initiator' in connector:
|
||||||
# multiattach volumes cannot be unmapped here, but will
|
# multiattach volumes cannot be unmapped here, but will
|
||||||
# be implicity unmapped when the volume is deleted.
|
# be implicity unmapped when the volume is deleted.
|
||||||
if not volume.get('multiattach'):
|
if not volume.get('multiattach'):
|
||||||
|
@ -245,7 +245,7 @@ class TydsClient(object):
|
|||||||
- target_block_name: The name of the target block.
|
- target_block_name: The name of the target block.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
pool_name, block_name, block_id, target_pool_name, target_pool_id,\
|
pool_name, block_name, block_id, target_pool_name, target_pool_id, \
|
||||||
target_block_name = args
|
target_block_name = args
|
||||||
params = {
|
params = {
|
||||||
'poolName': pool_name,
|
'poolName': pool_name,
|
||||||
|
@ -3079,7 +3079,7 @@ class VolumeManager(manager.CleanableManager,
|
|||||||
host)
|
host)
|
||||||
# Check if the driver retype provided a model update or
|
# Check if the driver retype provided a model update or
|
||||||
# just a retype indication
|
# just a retype indication
|
||||||
if type(ret) == tuple:
|
if type(ret) is tuple:
|
||||||
retyped, retype_model_update = ret
|
retyped, retype_model_update = ret
|
||||||
else:
|
else:
|
||||||
retyped = ret
|
retyped = ret
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
# process, which may cause wedges in the gate later.
|
# process, which may cause wedges in the gate later.
|
||||||
|
|
||||||
# Install bounded pep8/pyflakes first, then let flake8 install
|
# Install bounded pep8/pyflakes first, then let flake8 install
|
||||||
hacking>=5.0.0,<5.1.0 # Apache-2.0
|
hacking>=6.1.0,<6.2.0 # Apache-2.0
|
||||||
flake8-import-order # LGPLv3
|
flake8-import-order # LGPLv3
|
||||||
flake8-logging-format>=0.6.0 # Apache-2.0
|
flake8-logging-format>=0.6.0 # Apache-2.0
|
||||||
|
|
||||||
|
6
tox.ini
6
tox.ini
@ -233,7 +233,9 @@ commands =
|
|||||||
#
|
#
|
||||||
# E251 unexpected spaces around keyword / parameter equals
|
# E251 unexpected spaces around keyword / parameter equals
|
||||||
# reason: no improvement in readability
|
# reason: no improvement in readability
|
||||||
#
|
# E275: missing whitespace after keyword
|
||||||
|
# reason: many failures newly triggered in pycodestyle 2.9.0,
|
||||||
|
# evaluate if fixing is worthwhile
|
||||||
# E402 module level import not at top of file
|
# E402 module level import not at top of file
|
||||||
# reason: there are numerous places where we import modules
|
# reason: there are numerous places where we import modules
|
||||||
# later for legitimate reasons
|
# later for legitimate reasons
|
||||||
@ -249,7 +251,7 @@ commands =
|
|||||||
# reason: no real benefit
|
# reason: no real benefit
|
||||||
# G200 Logging statements should not include the exception
|
# G200 Logging statements should not include the exception
|
||||||
# reason: Many existing cases of this that may be legitimate
|
# reason: Many existing cases of this that may be legitimate
|
||||||
ignore = E251,E402,W503,W504,H101,G200
|
ignore = E251,E275,E402,W503,W504,H101,G200
|
||||||
# H904 Delay string interpolations at logging calls.
|
# H904 Delay string interpolations at logging calls.
|
||||||
enable-extensions = H106,H203,H904
|
enable-extensions = H106,H203,H904
|
||||||
exclude = .git,.venv,.tox,dist,tools,doc/ext,*egg,build
|
exclude = .git,.venv,.tox,dist,tools,doc/ext,*egg,build
|
||||||
|
Loading…
Reference in New Issue
Block a user