Merge "PowerMax Driver - Fix for legacy PowerMax OS around generations"

This commit is contained in:
Zuul 2021-10-13 19:17:34 +00:00 committed by Gerrit Code Review
commit bd63fa14b1
4 changed files with 40 additions and 1 deletions

View File

@ -2447,3 +2447,25 @@ class PowerMaxRestTest(test.TestCase):
exception.VolumeBackendAPIException,
self.rest.get_ip_interface_physical_port,
array_id, virtual_port, ip_address)
@mock.patch.object(rest.PowerMaxRest, 'get_volume_snaps',
return_value=[{'snap_name': 'snap_name',
'snap_id': tpd.PowerMaxData.snap_id}])
def test_get_snap_id(self, mock_snaps):
snap_id = self.rest.get_snap_id(
self.data.array, self.data.device_id,
self.data.test_snapshot_snap_name)
self.assertEqual(self.data.snap_id, snap_id)
@mock.patch.object(rest.PowerMaxRest, 'get_volume_snaps',
side_effect=[[{'snap_name': 'generation_int',
'generation': 0}],
[{'snap_name': 'generation_string',
'generation': '0'}]])
def test_get_snap_id_legacy_generation(self, mock_snaps):
self.rest.is_snap_id = False
for x in range(0, 2):
snap_id = self.rest.get_snap_id(
self.data.array, self.data.device_id,
self.data.test_snapshot_snap_name)
self.assertEqual('0', snap_id)

View File

@ -3403,7 +3403,7 @@ class PowerMaxRest(object):
message=exception_message)
else:
return snapshots[0].get('snap_id') if self.is_snap_id else (
snapshots[0].get('generation'))
self.utils.convert_to_string(snapshots[0].get('generation')))
def get_major_minor_ucode(self, array):
"""Get the major and minor parts of the ucode

View File

@ -2089,3 +2089,12 @@ class PowerMaxUtils(object):
service_level = str()
return array_id, srp, service_level, workload
@staticmethod
def convert_to_string(in_value):
"""Convert to string if value is an int
:param in_value: the input (most likely a str or int)
:returns: str
"""
return in_value if isinstance(in_value, str) else str(in_value)

View File

@ -0,0 +1,8 @@
---
fixes:
- |
PowerMax driver `bug #1938572
<https://bugs.launchpad.net/cinder/+bug/1938572>`_ :
Legacy PowerMax OS fix to convert an int to a string if the generation
of snapVX is returned as an int from REST so that a 0 does not equate
to False in python.