VNX: fix options incorrect behavior

Since Newton, the following options were incorrectly handled:

max_luns_per_storage_group: this option was ignored, and implicitly set
to 255 in storops, thus there is not way to set it to a larger number
for admin. This commit will add this feature back.

check_max_pool_luns_threshold: this option was obsoleted since driver
can detect this value automatically. This commit will remove this
option for driver code.

Closes-bug: #1738681

Change-Id: If3ca0999a745e6977345f208fc6edd00c86ccea9
This commit is contained in:
Peter Wang 2017-12-17 22:13:22 -05:00 committed by Ryan Liang
parent 6dccf35746
commit 04847424b4
9 changed files with 42 additions and 3 deletions

View File

@ -1181,6 +1181,10 @@ test_add_lun_to_ioclass:
_methods:
get_ioclass: *ioclass_true
test_set_max_luns_per_sg:
vnx: *vnx_base
###########################################################
# TestCommonAdapter
###########################################################

View File

@ -576,3 +576,9 @@ class TestClient(test.TestCase):
@res_mock.patch_client
def test_add_lun_to_ioclass(self, client, mocked):
client.add_lun_to_ioclass('test_ioclass', 1)
@res_mock.patch_client
def test_set_max_luns_per_sg(self, client, mocked):
with utils.patch_vnxstoragegroup as patch_sg:
client.set_max_luns_per_sg(300)
patch_sg.set_max_luns_per_sg.assert_called_with(300)

View File

@ -30,6 +30,9 @@ patch_sleep = mock.patch('time.sleep')
patch_vnxsystem = mock.patch('storops.VNXSystem')
patch_vnxstoragegroup = mock.patch('storops.vnx.resource.sg.VNXStorageGroup')
def load_yaml(file_name):
yaml_file = '{}/{}'.format(path.dirname(
path.abspath(__file__)), file_name)

View File

@ -61,6 +61,7 @@ class CommonAdapter(replication.ReplicationAdapter):
self.allowed_ports = None
self.force_delete_lun_in_sg = None
self.max_over_subscription_ratio = None
self.max_luns_per_storage_group = None
self.ignore_pool_full_threshold = None
self.reserved_percentage = None
self.destroy_empty_sg = None
@ -81,6 +82,8 @@ class CommonAdapter(replication.ReplicationAdapter):
self._normalize_config()
self.client = self._build_client_from_config(
self.config, self.queue_path)
self.client.set_max_luns_per_sg(
self.config.max_luns_per_storage_group)
# Replication related
if (self.active_backend_id in
common.ReplicationDeviceList.get_backend_ids(self.config)):

View File

@ -733,3 +733,8 @@ class Client(object):
def filter_sg(self, attached_lun_id):
return self.vnx.get_sg().shadow_copy(attached_lun=attached_lun_id)
def set_max_luns_per_sg(self, max_luns):
"""Sets max LUNs per storage group."""
storops.vnx.resource.sg.VNXStorageGroup.set_max_luns_per_sg(max_luns)
LOG.info('Set max LUNs per storage group to %s.', max_luns)

View File

@ -97,8 +97,9 @@ VNX_OPTS = [
'By default, the value is False.'),
cfg.BoolOpt('check_max_pool_luns_threshold',
default=False,
help='Report free_capacity_gb as 0 when the limit to '
'maximum number of pool LUNs is reached. '
deprecated_for_removal=True,
help='DEPRECATED: Report free_capacity_gb as 0 when the limit '
'to maximum number of pool LUNs is reached. '
'By default, the value is False.'),
cfg.BoolOpt('force_delete_lun_in_storagegroup',
default=False,

View File

@ -78,9 +78,11 @@ class VNXDriver(driver.ManageableVD,
10.2.0 - Add replication group support
11.0.0 - Fix failure of migration during cloning
12.0.0 - Add `volume revert to snapshot` support
12.1.0 - Adjust max_luns_per_storage_group and
check_max_pool_luns_threshold
"""
VERSION = '12.00.00'
VERSION = '12.01.00'
VENDOR = 'Dell EMC'
# ThirdPartySystems wiki page
CI_WIKI_NAME = "EMC_VNX_CI"

View File

@ -377,6 +377,11 @@ limit and will report 0 free capacity to the scheduler if the limit is reached.
So the scheduler will be able to skip this kind of pool-based back end that
runs out of the pool volume number.
.. note::
From Queens, ``check_max_pool_luns_threshold`` is obsolete. And the behavior
is like where ``check_max_pool_luns_threshold`` is set to ``True``.
iSCSI initiators
----------------

View File

@ -0,0 +1,10 @@
---
deprecations:
- |
Deprecate option `check_max_pool_luns_threshold`. The VNX driver will
always check the threshold.
fixes:
- |
Add option `max_luns_per_storage_group` back. The max LUNs per storage
group was set to 255 before. With the new option, admin can set it to a
larger number.