Skip to content

Commit

Permalink
Merge pull request #12 from Huawei/2.1.RC4
Browse files Browse the repository at this point in the history
Release 2.1.RC4
  • Loading branch information
doubletao318 authored Dec 31, 2019
2 parents 661fb73 + 58c78bd commit 1be04d2
Show file tree
Hide file tree
Showing 26 changed files with 7,451 additions and 36 deletions.
14 changes: 7 additions & 7 deletions Cinder/Newton/huawei_conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -560,19 +560,19 @@ def _replication_pair_sync_speed(self, xml_root):
def _get_local_minimum_fc_initiator(self, xml_root):
text = xml_root.findtext('FC/MinOnlineFCInitiator')
minimum_fc_initiator = constants.DEFAULT_MINIMUM_FC_INITIATOR_ONLINE
if text and not text.isdigit():
msg = (_("Invalid FC MinOnlineFCInitiator '%s', "
"MinOnlineFCInitiator must be a digit.") % text)
LOG.error(msg)
raise exception.InvalidInput(reason=msg)

if text and text.strip() and text.strip().isdigit():
try:
minimum_fc_initiator = int(text.strip())
if minimum_fc_initiator < 0:
msg = (_("Minimum FC initiator number %(num)s cannot"
" be set to a negative number.")
% {"num": minimum_fc_initiator})
LOG.error(msg)
raise exception.InvalidInput(reason=msg)
except Exception as err:
msg = (_("Minimum FC initiator number %(num)s is set"
" too large, reason is %(err)s")
% {"num": minimum_fc_initiator, "err": err})
% {"num": text.strip(), "err": err})
LOG.error(msg)
raise exception.InvalidInput(reason=msg)
setattr(self.conf, 'min_fc_ini_online', minimum_fc_initiator)
14 changes: 7 additions & 7 deletions Cinder/Ocata/huawei_conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -560,19 +560,19 @@ def _replication_pair_sync_speed(self, xml_root):
def _get_local_minimum_fc_initiator(self, xml_root):
text = xml_root.findtext('FC/MinOnlineFCInitiator')
minimum_fc_initiator = constants.DEFAULT_MINIMUM_FC_INITIATOR_ONLINE
if text and not text.isdigit():
msg = (_("Invalid FC MinOnlineFCInitiator '%s', "
"MinOnlineFCInitiator must be a digit.") % text)
LOG.error(msg)
raise exception.InvalidInput(reason=msg)

if text and text.strip() and text.strip().isdigit():
try:
minimum_fc_initiator = int(text.strip())
if minimum_fc_initiator < 0:
msg = (_("Minimum FC initiator number %(num)s cannot"
" be set to a negative number.")
% {"num": minimum_fc_initiator})
LOG.error(msg)
raise exception.InvalidInput(reason=msg)
except Exception as err:
msg = (_("Minimum FC initiator number %(num)s is set"
" too large, reason is %(err)s")
% {"num": minimum_fc_initiator, "err": err})
% {"num": text.strip(), "err": err})
LOG.error(msg)
raise exception.InvalidInput(reason=msg)
setattr(self.conf, 'min_fc_ini_online', minimum_fc_initiator)
14 changes: 7 additions & 7 deletions Cinder/Pike/huawei_conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -560,19 +560,19 @@ def _replication_pair_sync_speed(self, xml_root):
def _get_local_minimum_fc_initiator(self, xml_root):
text = xml_root.findtext('FC/MinOnlineFCInitiator')
minimum_fc_initiator = constants.DEFAULT_MINIMUM_FC_INITIATOR_ONLINE
if text and not text.isdigit():
msg = (_("Invalid FC MinOnlineFCInitiator '%s', "
"MinOnlineFCInitiator must be a digit.") % text)
LOG.error(msg)
raise exception.InvalidInput(reason=msg)

if text and text.strip() and text.strip().isdigit():
try:
minimum_fc_initiator = int(text.strip())
if minimum_fc_initiator < 0:
msg = (_("Minimum FC initiator number %(num)s cannot"
" be set to a negative number.")
% {"num": minimum_fc_initiator})
LOG.error(msg)
raise exception.InvalidInput(reason=msg)
except Exception as err:
msg = (_("Minimum FC initiator number %(num)s is set"
" too large, reason is %(err)s")
% {"num": minimum_fc_initiator, "err": err})
% {"num": text.strip(), "err": err})
LOG.error(msg)
raise exception.InvalidInput(reason=msg)
setattr(self.conf, 'min_fc_ini_online', minimum_fc_initiator)
4 changes: 2 additions & 2 deletions Cinder/Pike/huawei_driver.py
Original file line number Diff line number Diff line change
Expand Up @@ -2997,8 +2997,8 @@ def initialize_connection(self, volume, connector):
iqns_in_host = (
self.client.get_host_iscsi_initiators(host_id))
if not (wwns_in_host or iqns_in_host or
self.client.is_host_associated_to_hostgroup(
host_id)):
self.client.is_host_associated_to_hostgroup(
host_id)):
self.client.remove_host(host_id)
msg = ("There is an Fc initiator in an invalid "
"state. If you want to continue to attach "
Expand Down
14 changes: 7 additions & 7 deletions Cinder/Queens/huawei_conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -560,19 +560,19 @@ def _replication_pair_sync_speed(self, xml_root):
def _get_local_minimum_fc_initiator(self, xml_root):
text = xml_root.findtext('FC/MinOnlineFCInitiator')
minimum_fc_initiator = constants.DEFAULT_MINIMUM_FC_INITIATOR_ONLINE
if text and not text.isdigit():
msg = (_("Invalid FC MinOnlineFCInitiator '%s', "
"MinOnlineFCInitiator must be a digit.") % text)
LOG.error(msg)
raise exception.InvalidInput(reason=msg)

if text and text.strip() and text.strip().isdigit():
try:
minimum_fc_initiator = int(text.strip())
if minimum_fc_initiator < 0:
msg = (_("Minimum FC initiator number %(num)s cannot"
" be set to a negative number.")
% {"num": minimum_fc_initiator})
LOG.error(msg)
raise exception.InvalidInput(reason=msg)
except Exception as err:
msg = (_("Minimum FC initiator number %(num)s is set"
" too large, reason is %(err)s")
% {"num": minimum_fc_initiator, "err": err})
% {"num": text.strip(), "err": err})
LOG.error(msg)
raise exception.InvalidInput(reason=msg)
setattr(self.conf, 'min_fc_ini_online', minimum_fc_initiator)
4 changes: 2 additions & 2 deletions Cinder/Rocky/huawei_base_driver.py
Original file line number Diff line number Diff line change
Expand Up @@ -261,7 +261,7 @@ def _update_support_capability(self):
if self.support_capability["Effective Capacity"]:
self.support_capability["SmartDedupe[\s\S]*LUN"] = True
self.support_capability["SmartCompression[\s\S]*LUN"] = True
del self.support_capability["Effective Capacity"]
del self.support_capability["Effective Capacity"]

self._update_hypermetro_capability()
self._update_replication_capability()
Expand Down Expand Up @@ -720,7 +720,7 @@ def _change_same_host_lun_id(self, local_mapping, remote_mapping):
if local_mapping['hostlun_id'] == remote_mapping['hostlun_id']:
return local_mapping['hostlun_id']

for i in xrange(1, 512):
for i in range(1, 512):
if i in loc_aval_host_lun_ids and i in rmt_aval_host_lun_ids:
same_host_lun_id = i
break
Expand Down
2 changes: 1 addition & 1 deletion Cinder/Rocky/huawei_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -425,7 +425,7 @@ def get_lun_info(client, volume):
lun_info = client.get_lun_info_by_name(volume_name)

if not lun_info and metadata.get('huawei_lun_id'):
lun_info = client.get_lun_info_by_id(metadata['huawei_lun_id'])
lun_info = client.get_lun_info_filter_id(metadata['huawei_lun_id'])

if lun_info and ('huawei_lun_wwn' in metadata and
lun_info.get('WWN') != metadata['huawei_lun_wwn']):
Expand Down
6 changes: 6 additions & 0 deletions Cinder/Rocky/rest_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -173,6 +173,12 @@ def get_lun_info_by_id(self, lun_id):
_assert_result(result, 'Get lun info by id %s error.', lun_id)
return result['data']

def get_lun_info_filter_id(self, lun_id):
result = self.get("?filter=ID::%(lun_id)s", lun_id=lun_id)
_assert_result(result, 'Get lun info filter id %s error.', lun_id)
if result.get('data'):
return result['data'][0]

def get_lun_host_lun_id(self, host_id, lun_id):
result = self.get(
"/associate?ASSOCIATEOBJTYPE=21&ASSOCIATEOBJID=%(id)s", id=host_id)
Expand Down
4 changes: 2 additions & 2 deletions Cinder/Stein/huawei_base_driver.py
Original file line number Diff line number Diff line change
Expand Up @@ -261,7 +261,7 @@ def _update_support_capability(self):
if self.support_capability["Effective Capacity"]:
self.support_capability["SmartDedupe[\s\S]*LUN"] = True
self.support_capability["SmartCompression[\s\S]*LUN"] = True
del self.support_capability["Effective Capacity"]
del self.support_capability["Effective Capacity"]

self._update_hypermetro_capability()
self._update_replication_capability()
Expand Down Expand Up @@ -720,7 +720,7 @@ def _change_same_host_lun_id(self, local_mapping, remote_mapping):
if local_mapping['hostlun_id'] == remote_mapping['hostlun_id']:
return local_mapping['hostlun_id']

for i in xrange(1, 512):
for i in range(1, 512):
if i in loc_aval_host_lun_ids and i in rmt_aval_host_lun_ids:
same_host_lun_id = i
break
Expand Down
2 changes: 1 addition & 1 deletion Cinder/Stein/huawei_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -425,7 +425,7 @@ def get_lun_info(client, volume):
lun_info = client.get_lun_info_by_name(volume_name)

if not lun_info and metadata.get('huawei_lun_id'):
lun_info = client.get_lun_info_by_id(metadata['huawei_lun_id'])
lun_info = client.get_lun_info_filter_id(metadata['huawei_lun_id'])

if lun_info and ('huawei_lun_wwn' in metadata and
lun_info.get('WWN') != metadata['huawei_lun_wwn']):
Expand Down
6 changes: 6 additions & 0 deletions Cinder/Stein/rest_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -173,6 +173,12 @@ def get_lun_info_by_id(self, lun_id):
_assert_result(result, 'Get lun info by id %s error.', lun_id)
return result['data']

def get_lun_info_filter_id(self, lun_id):
result = self.get("?filter=ID::%(lun_id)s", lun_id=lun_id)
_assert_result(result, 'Get lun info filter id %s error.', lun_id)
if result.get('data'):
return result['data'][0]

def get_lun_host_lun_id(self, host_id, lun_id):
result = self.get(
"/associate?ASSOCIATEOBJTYPE=21&ASSOCIATEOBJID=%(id)s", id=host_id)
Expand Down
1 change: 1 addition & 0 deletions Cinder/Train/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
"""Version: 2.2.4"""
164 changes: 164 additions & 0 deletions Cinder/Train/constants.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,164 @@
# Copyright (c) 2016 Huawei Technologies Co., Ltd.
# All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.

STATUS_INITIALIZE = '0'
STATUS_HEALTH = '1'
LUN_TYPE = '11'
SNAPSHOT_TYPE = '27'
BLOCK_POOL_TYPE = '1'

HOSTGROUP_PREFIX = 'OpenStack_HostGroup_'
LUNGROUP_PREFIX = 'OpenStack_LunGroup_'
MAPPING_VIEW_PREFIX = 'OpenStack_Mapping_View_'
PORTGROUP_PREFIX = 'OpenStack_PortGroup_'
QOS_NAME_PREFIX = 'OpenStack_'

FC_PORT_CONNECTED = '10'
CAPACITY_UNIT = 1024 * 1024 * 2
DEFAULT_WAIT_TIMEOUT = 3600 * 24 * 30
DEFAULT_WAIT_INTERVAL = 5
MAX_NAME_LENGTH = 31
SOCKET_TIMEOUT = 52
LOGIN_SOCKET_TIMEOUT = 4
PWD_EXPIRED_OR_INITIAL = (3, 4)

LUN_STATUS = (LUN_ONLINE, LUN_INITIALIZING, LUN_OFFLINE) = ('27', '53', '28')
SNAPSHOT_STATUS = (
SNAPSHOT_INITIALIZING, SNAPSHOT_ACTIVATED, SNAPSHOT_UNACTIVATED
) = ('53', '43', '45')

MIGRATION_STATUS_IN_PROCESS = (
MIGRATION_NORMAL, MIGRATION_QUEUING, MIGRATION_MIGRATING
) = ('1', '37', '75')
MIGRATION_STATUS_COMPLETE = (MIGRATION_COMPLETE,) = ('76',)
LUNCOPY_STATUS_COMPLETE = (LUNCOPY_COMPLETE,) = ('40',)

ERROR_CONNECT_TO_SERVER = -403
ERROR_UNAUTHORIZED_TO_SERVER = -401
OBJECT_NAME_ALREADY_EXIST = 1077948993
OBJECT_ID_NOT_UNIQUE = 1077948997
ERROR_VOLUME_NOT_EXIST = 1077939726
ERROR_LUN_NOT_EXIST = 1077936859
SNAPSHOT_NOT_EXIST = 1077937880
OBJECT_NOT_EXIST = 1077948996
HYPERMETRO_NOT_EXIST = 1077674242
HYPERMETRO_NOT_IN_GROUP = 1077675021
HYPERMETROGROUP_NOT_EXIST = 1077675010
HYPERMETRO_ALREADY_IN_GROUP = 1077675038
NO_HYPERMETRO_EXIST_IN_GROUP = 1077675022
HOSTGROUP_NOT_IN_MAPPINGVIEW = 1073804552
PORTGROUP_NOT_IN_MAPPINGVIEW = 1073804553
LUNGROUP_NOT_IN_MAPPINGVIEW = 1073804554
MIGRATION_NOT_EXIST = 1073806607
LUNCOPY_NOT_EXIST = 50338560
LUNCOPY_ALREADY_STOPPED = 1077950178
LUNCOPY_COMPLETED = 1077950180
PORTGROUP_NOT_EXIST = 1077951832
HOSTGROUP_NOT_EXIST = 1077937500
HOST_NOT_IN_HOSTGROUP = 1073745412
PORT_NOT_IN_PORTGROUP = 1073807618
INITIATOR_NOT_IN_HOST = 1077950342
HOST_NOT_EXIST = 1077937498
MAPPINGVIEW_NOT_EXIST = 1077951819
HOST_ALREADY_IN_HOSTGROUP = 1077937501
PORT_ALREADY_IN_PORTGROUP = 1077951833
HOSTGROUP_ALREADY_IN_MAPPINGVIEW = 1073804556
PORTGROUP_ALREADY_IN_MAPPINGVIEW = 1073804558
LUNGROUP_ALREADY_IN_MAPPINGVIEW = 1073804560

METRO_RUNNING_STATUS = (METRO_RUNNING_NORMAL, METRO_RUNNING_SYNC,
METRO_RUNNING_STOP, RUNNING_TO_BE_SYNC
) = ('1', '23', '41', '100')
METRO_HEALTH_NORMAL = '1'

THICK_LUNTYPE = '0'
THIN_LUNTYPE = '1'
LUN_TYPE_MAP = {'Thick': THICK_LUNTYPE,
'Thin': THIN_LUNTYPE}

QOS_INACTIVATED = '45'
LOWER_LIMIT_KEYS = ('MINIOPS', 'LATENCY', 'MINBANDWIDTH')
UPPER_LIMIT_KEYS = ('MAXIOPS', 'MAXBANDWIDTH')

REPLICA_SYNC_MODEL = '1'
REPLICA_ASYNC_MODEL = '2'
REPLICA_SPEED = '2'
REPLICA_PERIOD = '3600'
REPLICA_SECOND_RO = '2'
REPLICA_SECOND_RW = '3'
REPLICA_CG_PERIOD = '60'

REPLICA_RUNNING_STATUS_SYNC = '23'
REPLICA_RUNNING_STATUS_NORMAL = '1'
REPLICA_RUNNING_STATUS_SPLIT = '26'
REPLICA_RUNNING_STATUS_INTERRUPTED = '34'
REPLICA_SECRES_DATA_SYNC = '1'
REPLICA_SECRES_DATA_COMPLETE = '2'
REPLICA_HEALTH_STATUS_NORMAL = '1'

REPLICATION_PAIR_NOT_EXIST = 1077937923
REPLICATION_GROUP_NOT_EXIST = 1077937924
REPLICATION_PAIR_NOT_GROUP_MEMBER = 1077937927
REPLICATION_GROUP_IS_EMPTY = 1077937960

VALID_PRODUCT = ('V3', 'V5', '18000', 'Dorado')
TIER_DISK_TYPES = ('ssd', 'sas', 'nl_sas')

AVAILABLE_FEATURE_STATUS = (1, 2)
CHECK_FEATURES = {
'SmartTier': None,
'SmartThin': None,
'SmartQoS': 'ioclass',
'SmartPartition': 'cachepartition',
'SmartCache': 'smartcachepartition',
'SmartMigration': 'LUN_MIGRATION',
'HyperMetro': 'HyperMetroPair',
'HyperReplication': 'REPLICATIONPAIR',
'HyperSnap': 'snapshot',
'HyperCopy': 'LUNCOPY',
'SmartDedupe[\s\S]*LUN': None,
'SmartCompression[\s\S]*LUN': None,
'Effective Capacity': None,
}

LUN_COPY_SPEED_TYPES = (
LUN_COPY_SPEED_LOW,
LUN_COPY_SPEED_MEDIUM,
LUN_COPY_SPEED_HIGH,
LUN_COPY_SPEED_HIGHEST
) = ('1', '2', '3', '4')
DEFAULT_CLONE_MODE = "luncopy"

HYPER_SYNC_SPEED_TYPES = (
HYPER_SYNC_SPEED_LOW,
HYPER_SYNC_SPEED_MEDIUM,
HYPER_SYNC_SPEED_HIGH,
HYPER_SYNC_SPEED_HIGHEST
) = ('1', '2', '3', '4')

REPLICA_SYNC_SPEED_TYPES = (
REPLICA_SYNC_SPEED_LOW,
REPLICA_SYNC_SPEED_MEDIUM,
REPLICA_SYNC_SPEED_HIGH,
REPLICA_SYNC_SPEED_HIGHEST
) = ('1', '2', '3', '4')

CLONE_STATUS_HEALTH = '0'
CLONE_STATUS_COMPLETE = (CLONE_COMPLETE,) = ('2',)
CLONE_PAIR_NOT_EXIST = "1073798147"
SUPPORT_CLONE_PAIR_VERSION = "V600R003C00"
GET_PATCH_NUM = 100

DEFAULT_MINIMUM_FC_INITIATOR_ONLINE = 0
Loading

0 comments on commit 1be04d2

Please sign in to comment.