Hitachi: Wait until the volume can be deleted

In Hitachi Storage, after create cloned volume, it may take time to transition
a volume status in the storage, and it may not be possible to delete the cloned
source volume immediately.
This issue must be resolved for the Hitachi driver to work successfuly
cinder-tempest-plugin.
We add wait processing in the function for checking status to solve this issue.

Change-Id: Ic79066792294d6efb3aa70b5811af4d143d7d271
Closes-Bug: #1908792
This commit is contained in:
Kazumasa Nomura 2020-12-24 05:10:27 +00:00
parent 8240195bd6
commit acfb3361cd
3 changed files with 51 additions and 0 deletions

View File

@ -205,6 +205,18 @@ GET_SNAPSHOTS_RESULT = {
], ],
} }
GET_SNAPSHOTS_RESULT_BUSY = {
"data": [
{
"primaryOrSecondary": "P-VOL",
"status": "PSUP",
"pvolLdevId": 0,
"muNumber": 1,
"svolLdevId": 1,
},
],
}
GET_POOLS_RESULT = { GET_POOLS_RESULT = {
"data": [ "data": [
{ {
@ -284,6 +296,8 @@ def reduce_retrying_time(func):
backup_exec_retry_interval = hbsd_rest_api._EXEC_RETRY_INTERVAL backup_exec_retry_interval = hbsd_rest_api._EXEC_RETRY_INTERVAL
backup_rest_server_restart_timeout = ( backup_rest_server_restart_timeout = (
hbsd_rest_api._REST_SERVER_RESTART_TIMEOUT) hbsd_rest_api._REST_SERVER_RESTART_TIMEOUT)
backup_default_process_waittime = (
hbsd_utils.DEFAULT_PROCESS_WAITTIME)
hbsd_rest_api._LOCK_WAITTIME = 0.01 hbsd_rest_api._LOCK_WAITTIME = 0.01
hbsd_rest_api._EXEC_MAX_WAITTIME = 0.01 hbsd_rest_api._EXEC_MAX_WAITTIME = 0.01
hbsd_rest_api._JOB_API_RESPONSE_TIMEOUT = 0.01 hbsd_rest_api._JOB_API_RESPONSE_TIMEOUT = 0.01
@ -291,6 +305,7 @@ def reduce_retrying_time(func):
hbsd_rest_api._EXTEND_WAITTIME = 0.01 hbsd_rest_api._EXTEND_WAITTIME = 0.01
hbsd_rest_api._EXEC_RETRY_INTERVAL = 0.004 hbsd_rest_api._EXEC_RETRY_INTERVAL = 0.004
hbsd_rest_api._REST_SERVER_RESTART_TIMEOUT = 0.02 hbsd_rest_api._REST_SERVER_RESTART_TIMEOUT = 0.02
hbsd_utils.DEFAULT_PROCESS_WAITTIME = 0.01
func(*args, **kwargs) func(*args, **kwargs)
hbsd_rest_api._LOCK_WAITTIME = backup_lock_waittime hbsd_rest_api._LOCK_WAITTIME = backup_lock_waittime
hbsd_rest_api._EXEC_MAX_WAITTIME = backup_exec_max_waittime hbsd_rest_api._EXEC_MAX_WAITTIME = backup_exec_max_waittime
@ -302,6 +317,8 @@ def reduce_retrying_time(func):
hbsd_rest_api._EXEC_RETRY_INTERVAL = backup_exec_retry_interval hbsd_rest_api._EXEC_RETRY_INTERVAL = backup_exec_retry_interval
hbsd_rest_api._REST_SERVER_RESTART_TIMEOUT = ( hbsd_rest_api._REST_SERVER_RESTART_TIMEOUT = (
backup_rest_server_restart_timeout) backup_rest_server_restart_timeout)
hbsd_utils.DEFAULT_PROCESS_WAITTIME = (
backup_default_process_waittime)
return wrapper return wrapper
@ -544,6 +561,31 @@ class HBSDRESTFCDriverTest(test.TestCase):
self.driver.delete_volume(TEST_VOLUME[0]) self.driver.delete_volume(TEST_VOLUME[0])
self.assertEqual(4, request.call_count) self.assertEqual(4, request.call_count)
@mock.patch.object(requests.Session, "request")
def test_delete_volume_temporary_busy(self, request):
request.side_effect = [FakeResponse(200, GET_LDEV_RESULT_PAIR),
FakeResponse(200, GET_SNAPSHOTS_RESULT_BUSY),
FakeResponse(200, GET_LDEV_RESULT),
FakeResponse(200, GET_LDEV_RESULT),
FakeResponse(200, GET_LDEV_RESULT),
FakeResponse(200, GET_LDEV_RESULT),
FakeResponse(202, COMPLETED_SUCCEEDED_RESULT)]
self.driver.delete_volume(TEST_VOLUME[0])
self.assertEqual(7, request.call_count)
@reduce_retrying_time
@mock.patch.object(requests.Session, "request")
def test_delete_volume_busy_timeout(self, request):
request.side_effect = [FakeResponse(200, GET_LDEV_RESULT_PAIR),
FakeResponse(200, GET_SNAPSHOTS_RESULT_BUSY),
FakeResponse(200, GET_LDEV_RESULT_PAIR),
FakeResponse(200, GET_LDEV_RESULT_PAIR),
FakeResponse(200, GET_LDEV_RESULT_PAIR)]
self.assertRaises(hbsd_utils.HBSDError,
self.driver.delete_volume,
TEST_VOLUME[0])
self.assertGreater(request.call_count, 2)
@mock.patch.object(requests.Session, "request") @mock.patch.object(requests.Session, "request")
def test_extend_volume(self, request): def test_extend_volume(self, request):
request.side_effect = [FakeResponse(200, GET_LDEV_RESULT), request.side_effect = [FakeResponse(200, GET_LDEV_RESULT),

View File

@ -648,6 +648,9 @@ class HBSDREST(common.HBSDCommon):
return None return None
pvol, svol_info = self._get_copy_pair_info(ldev) pvol, svol_info = self._get_copy_pair_info(ldev)
if svol_info and svol_info[0]['status'] in ('SMPP', 'PSUP'):
self._wait_copy_pair_deleting(svol_info[0]['ldev'])
return self.get_pair_info(ldev)
if pvol is not None: if pvol is not None:
pair_info['pvol'] = pvol pair_info['pvol'] = pvol
pair_info.setdefault('svol_info', []) pair_info.setdefault('svol_info', [])

View File

@ -0,0 +1,6 @@
---
fixes:
- |
Hitachi driver `bug #1908792
<https://bugs.launchpad.net/cinder/+bug/1908792>`_: Fix for Hitachi driver
allowing delete_volume after create_cloned_volume.