PowerMax driver - changing from 8.4 to 9.0 REST endpoints

Changing unisphere for powermax REST endpoint from 8.4 to 9.0.

Change-Id: I6c05647f01151f19223d153deceb4db4a46e0f0b
Closes-Bug: #1808539
This commit is contained in:
Helen Walsh 2018-12-14 16:04:56 +00:00
parent 76fd03819c
commit c71fb7839c
6 changed files with 70 additions and 56 deletions

View File

@ -92,7 +92,7 @@ class PowerMaxCommonData(object):
device_id4 = '00004'
rdf_group_name = '23_24_007'
rdf_group_no = '70'
u4v_version = '84'
u4v_version = '90'
storagegroup_name_source = 'Grp_source_sg'
storagegroup_name_target = 'Grp_target_sg'
group_snapshot_name = 'Grp_snapshot'
@ -533,13 +533,13 @@ class PowerMaxCommonData(object):
sg_list_rep = [storagegroup_name_with_id]
srp_details = {"srpSloDemandId": ["Bronze", "Diamond", "Gold",
"None", "Optimized", "Silver"],
srp_details = {"srp_capacity": {u'subscribed_total_tb': 93.52,
u'usable_used_tb': 8.62,
u'usable_total_tb': 24.45,
u'snapshot_modified_tb': 0.0,
u'subscribed_allocated_tb': 18.77,
u'snapshot_total_tb': 1.58},
"srpId": srp,
"total_used_cap_gb": 5244.7,
"total_usable_cap_gb": 20514.4,
"total_subscribed_cap_gb": 84970.1,
"fba_used_capacity": 5244.7,
"reserved_cap_percent": 10}
array_info_wl = {'RestServerIp': '1.1.1.1', 'RestServerPort': 3448,
@ -633,7 +633,7 @@ class PowerMaxCommonData(object):
# replication
volume_snap_vx = {"snapshotLnks": [],
"snapshotSrcs": [
"snapshotSrc": [
{"generation": 0,
"linkedDevices": [
{"targetDevice": device_id2,
@ -1101,8 +1101,6 @@ class FakeRequestsSession(object):
return_object = self._sloprovisioning_mv(url)
elif 'portgroup' in url:
return_object = self._sloprovisioning_pg(url)
elif 'director' in url:
return_object = self._sloprovisioning_port(url)
elif 'host' in url:
return_object = self._sloprovisioning_ig(url)
elif 'initiator' in url:
@ -1122,7 +1120,10 @@ class FakeRequestsSession(object):
return_object = self._replication(url)
elif 'system' in url:
return_object = self._system(url)
if 'director' in url:
return_object = self._system_port(url)
else:
return_object = self._system(url)
elif 'headroom' in url:
return_object = self.data.headroom
@ -1168,7 +1169,7 @@ class FakeRequestsSession(object):
break
return return_object
def _sloprovisioning_port(self, url):
def _system_port(self, url):
return_object = None
for port in self.data.port_list:
if port['symmetrixPort']['symmetrixPortKey']['directorId'] in url:
@ -2250,15 +2251,16 @@ class PowerMaxRestTest(test.TestCase):
def test_add_child_sg_to_parent_sg(self):
payload = {"editStorageGroupActionParam": {
"addExistingStorageGroupParam": {
"storageGroupId": [self.data.storagegroup_name_f]}}}
"expandStorageGroupParam": {
"addExistingStorageGroupParam": {
"storageGroupId": [self.data.storagegroup_name_f]}}}}
with mock.patch.object(self.rest, 'modify_storage_group',
return_value=(202, self.data.job_list[0])):
self.rest.add_child_sg_to_parent_sg(
self.data.array, self.data.storagegroup_name_f,
self.data.parent_sg_f, self.data.extra_specs)
self.rest.modify_storage_group.assert_called_once_with(
self.data.array, self.data.parent_sg_f, payload, version='83')
self.data.array, self.data.parent_sg_f, payload)
def test_remove_child_sg_from_parent_sg(self):
payload = {"editStorageGroupActionParam": {
@ -2771,7 +2773,7 @@ class PowerMaxRestTest(test.TestCase):
def test_create_volume_snap(self):
snap_name = (self.data.volume_snap_vx
['snapshotSrcs'][0]['snapshotName'])
['snapshotSrc'][0]['snapshotName'])
device_id = self.data.device_id
extra_specs = self.data.extra_specs
payload = {"deviceNameListSource": [{"name": device_id}],
@ -2802,9 +2804,9 @@ class PowerMaxRestTest(test.TestCase):
array = self.data.array
source_id = self.data.device_id
target_id = (self.data.volume_snap_vx
['snapshotSrcs'][0]['linkedDevices'][0]['targetDevice'])
['snapshotSrc'][0]['linkedDevices'][0]['targetDevice'])
snap_name = (self.data.volume_snap_vx
['snapshotSrcs'][0]['snapshotName'])
['snapshotSrc'][0]['snapshotName'])
extra_specs = self.data.extra_specs
payload = {"deviceNameListSource": [{"name": source_id}],
"deviceNameListTarget": [
@ -2866,7 +2868,7 @@ class PowerMaxRestTest(test.TestCase):
def test_delete_volume_snap(self):
array = self.data.array
snap_name = (self.data.volume_snap_vx
['snapshotSrcs'][0]['snapshotName'])
['snapshotSrc'][0]['snapshotName'])
source_device_id = self.data.device_id
payload = {"deviceNameListSource": [{"name": source_device_id}],
"generation": 0}
@ -2881,7 +2883,7 @@ class PowerMaxRestTest(test.TestCase):
def test_delete_volume_snap_restore(self):
array = self.data.array
snap_name = (self.data.volume_snap_vx
['snapshotSrcs'][0]['snapshotName'])
['snapshotSrc'][0]['snapshotName'])
source_device_id = self.data.device_id
payload = {"deviceNameListSource": [{"name": source_device_id}],
"restore": True, "generation": 0}
@ -2902,23 +2904,23 @@ class PowerMaxRestTest(test.TestCase):
def test_get_volume_snap(self):
array = self.data.array
snap_name = (self.data.volume_snap_vx
['snapshotSrcs'][0]['snapshotName'])
['snapshotSrc'][0]['snapshotName'])
device_id = self.data.device_id
ref_snap = self.data.volume_snap_vx['snapshotSrcs'][0]
ref_snap = self.data.volume_snap_vx['snapshotSrc'][0]
snap = self.rest.get_volume_snap(array, device_id, snap_name)
self.assertEqual(ref_snap, snap)
def test_get_volume_snap_none(self):
array = self.data.array
snap_name = (self.data.volume_snap_vx
['snapshotSrcs'][0]['snapshotName'])
['snapshotSrc'][0]['snapshotName'])
device_id = self.data.device_id
with mock.patch.object(self.rest, 'get_volume_snap_info',
return_value=None):
snap = self.rest.get_volume_snap(array, device_id, snap_name)
self.assertIsNone(snap)
with mock.patch.object(self.rest, 'get_volume_snap_info',
return_value={'snapshotSrcs': []}):
return_value={'snapshotSrc': []}):
snap = self.rest.get_volume_snap(array, device_id, snap_name)
self.assertIsNone(snap)
@ -2942,11 +2944,11 @@ class PowerMaxRestTest(test.TestCase):
source_id = self.data.device_id
generation = 0
target_id = (self.data.volume_snap_vx
['snapshotSrcs'][0]['linkedDevices'][0]['targetDevice'])
['snapshotSrc'][0]['linkedDevices'][0]['targetDevice'])
snap_name = (self.data.volume_snap_vx
['snapshotSrcs'][0]['snapshotName'])
['snapshotSrc'][0]['snapshotName'])
ref_sync = (self.data.volume_snap_vx
['snapshotSrcs'][0]['linkedDevices'][0])
['snapshotSrc'][0]['linkedDevices'][0])
sync = self.rest.get_sync_session(
array, source_id, snap_name, target_id, generation)
self.assertEqual(ref_sync, sync)
@ -3663,10 +3665,11 @@ class PowerMaxProvisionTest(test.TestCase):
def test_get_srp_pool_stats(self):
array = self.data.array
array_info = self.common.pool_info['arrays_info'][0]
ref_stats = (self.data.srp_details['total_usable_cap_gb'],
float(self.data.srp_details['total_usable_cap_gb']
- self.data.srp_details['total_used_cap_gb']),
self.data.srp_details['total_subscribed_cap_gb'],
srp_capacity = self.data.srp_details['srp_capacity']
ref_stats = ((srp_capacity['usable_total_tb'] * 1024),
float((srp_capacity['usable_total_tb'] * 1024)
- (srp_capacity['usable_used_tb'] * 1024)),
(srp_capacity['subscribed_total_tb'] * 1024),
self.data.srp_details['reserved_cap_percent'])
stats = self.provision.get_srp_pool_stats(array, array_info)
self.assertEqual(ref_stats, stats)
@ -3679,9 +3682,10 @@ class PowerMaxProvisionTest(test.TestCase):
stats = self.provision.get_srp_pool_stats(array, array_info)
self.assertEqual(ref_stats, stats)
# cannot report on all stats
with mock.patch.object(self.provision.rest, 'get_srp_by_name',
return_value={'total_usable_cap_gb': 33}):
ref_stats = (33, 0, 0, 0)
with mock.patch.object(
self.provision.rest, 'get_srp_by_name',
return_value={'srp_capacity': {'usable_total_tb': 33}}):
ref_stats = (33 * 1024, 0, 0, 0)
stats = self.provision.get_srp_pool_stats(array, array_info)
self.assertEqual(ref_stats, stats)

View File

@ -104,6 +104,7 @@ class PowerMaxFCDriver(san.SanDriver, driver.FibreChannelDriver):
- Support for failover to secondary Unisphere
(bp/vmax-unisphere-failover)
- Rebrand from VMAX to PowerMax(bp/vmax-powermax-rebrand)
- Change from 84 to 90 REST endpoints (bug #1808539)
"""
VERSION = "4.0.0"

View File

@ -109,6 +109,7 @@ class PowerMaxISCSIDriver(san.SanISCSIDriver):
- Support for failover to secondary Unisphere
(bp/vmax-unisphere-failover)
- Rebrand from VMAX to PowerMax(bp/vmax-powermax-rebrand)
- Change from 84 to 90 REST endpoints (bug #1808539)
"""
VERSION = "4.0.0"

View File

@ -17,6 +17,7 @@ import time
from oslo_log import log as logging
from oslo_service import loopingcall
from oslo_utils import units
from cinder import coordination
from cinder import exception
@ -422,14 +423,16 @@ class PowerMaxProvision(object):
{'srpName': srp, 'array': array})
return 0, 0, 0, 0, False
try:
total_capacity_gb = srp_details['total_usable_cap_gb']
srp_capacity = srp_details['srp_capacity']
total_capacity_gb = srp_capacity['usable_total_tb'] * units.Ki
try:
used_capacity_gb = srp_details['total_used_cap_gb']
used_capacity_gb = srp_capacity['usable_used_tb'] * units.Ki
remaining_capacity_gb = float(
total_capacity_gb - used_capacity_gb)
except KeyError:
remaining_capacity_gb = srp_details['fba_free_capacity']
subscribed_capacity_gb = srp_details['total_subscribed_cap_gb']
LOG.error("Unable to retrieve remaining_capacity_gb.")
subscribed_capacity_gb = (
srp_capacity['subscribed_total_tb'] * units.Ki)
array_reserve_percent = srp_details['reserved_cap_percent']
except KeyError:
pass

View File

@ -39,7 +39,7 @@ LOG = logging.getLogger(__name__)
SLOPROVISIONING = 'sloprovisioning'
REPLICATION = 'replication'
SYSTEM = 'system'
U4V_VERSION = '84'
U4V_VERSION = '90'
UCODE_5978 = '5978'
retry_exc_tuple = (exception.VolumeBackendAPIException,)
# HTTP constants
@ -732,10 +732,10 @@ class PowerMaxRest(object):
:param extra_specs: the extra specifications
"""
payload = {"editStorageGroupActionParam": {
"addExistingStorageGroupParam": {
"storageGroupId": [child_sg]}}}
sc, job = self.modify_storage_group(array, parent_sg, payload,
version="83")
"expandStorageGroupParam": {
"addExistingStorageGroupParam": {
"storageGroupId": [child_sg]}}}}
sc, job = self.modify_storage_group(array, parent_sg, payload)
self.wait_for_job('Add child sg to parent sg', sc, job, extra_specs)
def remove_child_sg_from_parent_sg(
@ -1409,7 +1409,7 @@ class PowerMaxRest(object):
resource_name = ('%(directorId)s/port/%(port_number)s'
% {'directorId': dir_id, 'port_number': port_no})
return self.get_resource(array, SLOPROVISIONING, 'director',
return self.get_resource(array, SYSTEM, 'director',
resource_name=resource_name)
def get_iscsi_ip_address_and_iqn(self, array, port_id):
@ -1476,9 +1476,8 @@ class PowerMaxRest(object):
:param params: dict of optional params
:returns: list of initiators
"""
version = '90' if self.is_next_gen_array(array) else U4V_VERSION
init_dict = self.get_resource(array, SLOPROVISIONING, 'initiator',
params=params, version=version)
params=params)
try:
init_list = init_dict['initiatorId']
except (KeyError, TypeError):
@ -1846,9 +1845,9 @@ class PowerMaxRest(object):
snapshot = None
snap_info = self.get_volume_snap_info(array, device_id)
if snap_info:
if (snap_info.get('snapshotSrcs') and
bool(snap_info['snapshotSrcs'])):
for snap in snap_info['snapshotSrcs']:
if (snap_info.get('snapshotSrc') and
bool(snap_info['snapshotSrc'])):
for snap in snap_info['snapshotSrc']:
if snap['snapshotName'] == snap_name:
if snap['generation'] == generation:
snapshot = snap
@ -1865,8 +1864,8 @@ class PowerMaxRest(object):
snapshot_list = []
snap_info = self.get_volume_snap_info(array, source_device_id)
if snap_info:
if bool(snap_info['snapshotSrcs']):
snapshot_list = snap_info['snapshotSrcs']
if bool(snap_info['snapshotSrc']):
snapshot_list = snap_info['snapshotSrc']
return snapshot_list
def is_vol_in_rep_session(self, array, device_id):
@ -1985,11 +1984,14 @@ class PowerMaxRest(object):
snap_dict_list = []
snapshots = self.get_volume_snapshot_list(array, source_device_id)
for snapshot in snapshots:
if bool(snapshot['linkedDevices']):
link_info = {'linked_vols': snapshot['linkedDevices'],
'snap_name': snapshot['snapshotName'],
'generation': snapshot['generation']}
snap_dict_list.append(link_info)
try:
if bool(snapshot['linkedDevices']):
link_info = {'linked_vols': snapshot['linkedDevices'],
'snap_name': snapshot['snapshotName'],
'generation': snapshot['generation']}
snap_dict_list.append(link_info)
except KeyError:
pass
return snap_dict_list
def get_snap_linked_device_list(self, array, source_device_id,

View File

@ -0,0 +1,3 @@
other:
- |
PowerMax driver - Changing 8.4 to 9.0 Unisphere for PowerMax REST endpoints.