Use HostAddressOpt for opts that accept IP and hostnames

Some configuration options were accepting both IP addresses
and hostnames. Since there was no specific OSLO opt type to
support this, we were using ``StrOpt``. The change [1] that
added support for ``HostAddressOpt`` type was merged in Ocata
and became available for use with oslo version 3.22.

This patch changes the opt type of configuration options to use
this more relevant opt type - HostAddressOpt.

[1] I77bdb64b7e6e56ce761d76696bc4448a9bd325eb

TrivialFix

Change-Id: I44ba478ff14a6184434dd030efd9b7fa92458c7a
This commit is contained in:
luqitao 2017-03-16 04:54:15 -04:00
parent 80b54ad59d
commit 86a1bc189c
18 changed files with 66 additions and 63 deletions

View File

@ -58,10 +58,10 @@ CONF.register_cli_opts(core_opts)
CONF.register_cli_opts(debug_opts) CONF.register_cli_opts(debug_opts)
global_opts = [ global_opts = [
cfg.StrOpt('my_ip', cfg.HostAddressOpt('my_ip',
default=netutils.get_my_ipv4(), default=netutils.get_my_ipv4(),
sample_default='<your_ip>', sample_default='<your_ip>',
help='IP address of this host.'), help='IP address of this host.'),
cfg.StrOpt('scheduler_topic', cfg.StrOpt('scheduler_topic',
default='manila-scheduler', default='manila-scheduler',
help='The topic scheduler nodes listen on.'), help='The topic scheduler nodes listen on.'),
@ -107,11 +107,12 @@ global_opts = [
cfg.StrOpt('data_manager', cfg.StrOpt('data_manager',
default='manila.data.manager.DataManager', default='manila.data.manager.DataManager',
help='Full class name for the data manager.'), help='Full class name for the data manager.'),
cfg.StrOpt('host', cfg.HostAddressOpt('host',
default=socket.gethostname(), default=socket.gethostname(),
sample_default='<your_hostname>', sample_default='<your_hostname>',
help='Name of this node. This can be an opaque identifier. ' help='Name of this node. This can be an opaque '
'It is not necessarily a hostname, FQDN, or IP address.'), 'identifier. It is not necessarily a hostname, '
'FQDN, or IP address.'),
# NOTE(vish): default to nova for compatibility with nova installs # NOTE(vish): default to nova for compatibility with nova installs
cfg.StrOpt('storage_availability_zone', cfg.StrOpt('storage_availability_zone',
default='nova', default='nova',

View File

@ -51,9 +51,10 @@ service_opts = [
help='Range of seconds to randomly delay when starting the ' help='Range of seconds to randomly delay when starting the '
'periodic task scheduler to reduce stampeding. ' 'periodic task scheduler to reduce stampeding. '
'(Disable by setting to 0)'), '(Disable by setting to 0)'),
cfg.StrOpt('osapi_share_listen', cfg.HostAddressOpt('osapi_share_listen',
default="::", default="::",
help='IP address for OpenStack Share API to listen on.'), help='IP address for OpenStack Share API to listen '
'on.'),
cfg.PortOpt('osapi_share_listen_port', cfg.PortOpt('osapi_share_listen_port',
default=8786, default=8786,
help='Port for OpenStack Share API to listen on.'), help='Port for OpenStack Share API to listen on.'),

View File

@ -30,8 +30,8 @@ EMC_NAS_OPTS = [
help='User name for the EMC server.'), help='User name for the EMC server.'),
cfg.StrOpt('emc_nas_password', cfg.StrOpt('emc_nas_password',
help='Password for the EMC server.'), help='Password for the EMC server.'),
cfg.StrOpt('emc_nas_server', cfg.HostAddressOpt('emc_nas_server',
help='EMC server hostname or IP address.'), help='EMC server hostname or IP address.'),
cfg.PortOpt('emc_nas_server_port', cfg.PortOpt('emc_nas_server_port',
default=8080, default=8080,
help='Port number for the EMC server.'), help='Port number for the EMC server.'),

View File

@ -45,8 +45,8 @@ GlusterfsManilaShare_opts = [
default='Gluster', default='Gluster',
help='Type of NFS server that mediate access to the Gluster ' help='Type of NFS server that mediate access to the Gluster '
'volumes (Gluster or Ganesha).'), 'volumes (Gluster or Ganesha).'),
cfg.StrOpt('glusterfs_ganesha_server_ip', cfg.HostAddressOpt('glusterfs_ganesha_server_ip',
help="Remote Ganesha server node's IP address."), help="Remote Ganesha server node's IP address."),
cfg.StrOpt('glusterfs_ganesha_server_username', cfg.StrOpt('glusterfs_ganesha_server_username',
default='root', default='root',
help="Remote Ganesha server node's username."), help="Remote Ganesha server node's username."),

View File

@ -44,8 +44,8 @@ from manila import utils
LOG = log.getLogger(__name__) LOG = log.getLogger(__name__)
hdfs_native_share_opts = [ hdfs_native_share_opts = [
cfg.StrOpt('hdfs_namenode_ip', cfg.HostAddressOpt('hdfs_namenode_ip',
help='The IP of the HDFS namenode.'), help='The IP of the HDFS namenode.'),
cfg.PortOpt('hdfs_namenode_port', cfg.PortOpt('hdfs_namenode_port',
default=9000, default=9000,
help='The port of HDFS namenode service.'), help='The port of HDFS namenode service.'),

View File

@ -30,10 +30,10 @@ from manila.share import utils
LOG = log.getLogger(__name__) LOG = log.getLogger(__name__)
hitachi_hnas_opts = [ hitachi_hnas_opts = [
cfg.StrOpt('hitachi_hnas_ip', cfg.HostAddressOpt('hitachi_hnas_ip',
deprecated_name='hds_hnas_ip', deprecated_name='hds_hnas_ip',
help="HNAS management interface IP for communication " help="HNAS management interface IP for communication "
"between Manila controller and HNAS."), "between Manila controller and HNAS."),
cfg.StrOpt('hitachi_hnas_user', cfg.StrOpt('hitachi_hnas_user',
deprecated_name='hds_hnas_user', deprecated_name='hds_hnas_user',
help="HNAS username Base64 String in order to perform tasks " help="HNAS username Base64 String in order to perform tasks "
@ -46,11 +46,12 @@ hitachi_hnas_opts = [
cfg.IntOpt('hitachi_hnas_evs_id', cfg.IntOpt('hitachi_hnas_evs_id',
deprecated_name='hds_hnas_evs_id', deprecated_name='hds_hnas_evs_id',
help="Specify which EVS this backend is assigned to."), help="Specify which EVS this backend is assigned to."),
cfg.StrOpt('hitachi_hnas_evs_ip', cfg.HostAddressOpt('hitachi_hnas_evs_ip',
deprecated_name='hds_hnas_evs_ip', deprecated_name='hds_hnas_evs_ip',
help="Specify IP for mounting shares."), help="Specify IP for mounting shares."),
cfg.StrOpt('hitachi_hnas_admin_network_ip', cfg.HostAddressOpt('hitachi_hnas_admin_network_ip',
help="Specify IP for mounting shares in the Admin network."), help="Specify IP for mounting shares in the Admin "
"network."),
cfg.StrOpt('hitachi_hnas_file_system_name', cfg.StrOpt('hitachi_hnas_file_system_name',
deprecated_name='hds_hnas_file_system_name', deprecated_name='hds_hnas_file_system_name',
help="Specify file-system name for creating shares."), help="Specify file-system name for creating shares."),
@ -59,10 +60,10 @@ hitachi_hnas_opts = [
secret=True, secret=True,
help="RSA/DSA private key value used to connect into HNAS. " help="RSA/DSA private key value used to connect into HNAS. "
"Required only if password is not provided."), "Required only if password is not provided."),
cfg.StrOpt('hitachi_hnas_cluster_admin_ip0', cfg.HostAddressOpt('hitachi_hnas_cluster_admin_ip0',
deprecated_name='hds_hnas_cluster_admin_ip0', deprecated_name='hds_hnas_cluster_admin_ip0',
help="The IP of the clusters admin node. Only set in HNAS " help="The IP of the clusters admin node. Only set in "
"multinode clusters."), "HNAS multinode clusters."),
cfg.IntOpt('hitachi_hnas_stalled_job_timeout', cfg.IntOpt('hitachi_hnas_stalled_job_timeout',
deprecated_name='hds_hnas_stalled_job_timeout', deprecated_name='hds_hnas_stalled_job_timeout',
default=30, default=30,

View File

@ -27,10 +27,10 @@ from manila.share.drivers.hitachi.hsp import rest
LOG = log.getLogger(__name__) LOG = log.getLogger(__name__)
hitachi_hsp_opts = [ hitachi_hsp_opts = [
cfg.StrOpt('hitachi_hsp_host', cfg.HostAddressOpt('hitachi_hsp_host',
required=True, required=True,
help="HSP management host for communication between Manila " help="HSP management host for communication between "
"controller and HSP."), "Manila controller and HSP."),
cfg.StrOpt('hitachi_hsp_username', cfg.StrOpt('hitachi_hsp_username',
required=True, required=True,
help="HSP username to perform tasks such as create filesystems" help="HSP username to perform tasks such as create filesystems"

View File

@ -132,10 +132,9 @@ HPE3PAR_OPTS = [
help="3PAR password for the user specified in hpe3par_username", help="3PAR password for the user specified in hpe3par_username",
secret=True, secret=True,
deprecated_name='hp3par_password'), deprecated_name='hp3par_password'),
cfg.StrOpt('hpe3par_san_ip', cfg.HostAddressOpt('hpe3par_san_ip',
default='', help="IP address of SAN controller",
help="IP address of SAN controller", deprecated_name='hp3par_san_ip'),
deprecated_name='hp3par_san_ip'),
cfg.StrOpt('hpe3par_san_login', cfg.StrOpt('hpe3par_san_login',
default='', default='',
help="Username for SAN controller", help="Username for SAN controller",

View File

@ -60,8 +60,8 @@ AVPATTERN = re.compile(r'\s*(?P<attr>\w+)\s*=\s*(?P<val>'
ERR_FILE_NOT_FOUND = 2 ERR_FILE_NOT_FOUND = 2
gpfs_share_opts = [ gpfs_share_opts = [
cfg.StrOpt('gpfs_share_export_ip', cfg.HostAddressOpt('gpfs_share_export_ip',
help='IP to be added to GPFS export string.'), help='IP to be added to GPFS export string.'),
cfg.StrOpt('gpfs_mount_point_base', cfg.StrOpt('gpfs_mount_point_base',
default='$state_path/mnt', default='$state_path/mnt',
help='Base folder where exported shares are located.'), help='Base folder where exported shares are located.'),

View File

@ -30,9 +30,10 @@ netapp_proxy_opts = [
'clustered Data ONTAP.')), ] 'clustered Data ONTAP.')), ]
netapp_connection_opts = [ netapp_connection_opts = [
cfg.StrOpt('netapp_server_hostname', cfg.HostAddressOpt('netapp_server_hostname',
deprecated_name='netapp_nas_server_hostname', deprecated_name='netapp_nas_server_hostname',
help='The hostname (or IP address) for the storage system.'), help='The hostname (or IP address) for the storage '
'system.'),
cfg.PortOpt('netapp_server_port', cfg.PortOpt('netapp_server_port',
help=('The TCP port to use for communication with the storage ' help=('The TCP port to use for communication with the storage '
'system or proxy server. If not specified, Data ONTAP ' 'system or proxy server. If not specified, Data ONTAP '

View File

@ -23,8 +23,8 @@
from oslo_config import cfg from oslo_config import cfg
nexenta_connection_opts = [ nexenta_connection_opts = [
cfg.StrOpt('nexenta_host', cfg.HostAddressOpt('nexenta_host',
help='IP address of Nexenta storage appliance.'), help='IP address of Nexenta storage appliance.'),
cfg.IntOpt('nexenta_rest_port', cfg.IntOpt('nexenta_rest_port',
default=8457, default=8457,
help='Port to connect to Nexenta REST API server.'), help='Port to connect to Nexenta REST API server.'),

View File

@ -37,9 +37,9 @@ qnap_manila_opts = [
cfg.StrOpt('qnap_management_url', cfg.StrOpt('qnap_management_url',
required=True, required=True,
help='The URL to manage QNAP Storage.'), help='The URL to manage QNAP Storage.'),
cfg.StrOpt('qnap_share_ip', cfg.HostAddressOpt('qnap_share_ip',
required=True, required=True,
help='NAS share IP for mounting shares.'), help='NAS share IP for mounting shares.'),
cfg.StrOpt('qnap_nas_login', cfg.StrOpt('qnap_nas_login',
required=True, required=True,
help='Username for QNAP storage.'), help='Username for QNAP storage.'),

View File

@ -125,13 +125,13 @@ no_share_servers_handling_mode_opts = [
"service_instance_name_or_id", "service_instance_name_or_id",
help="Name or ID of service instance in Nova to use for share " help="Name or ID of service instance in Nova to use for share "
"exports. Used only when share servers handling is disabled."), "exports. Used only when share servers handling is disabled."),
cfg.StrOpt( cfg.HostAddressOpt(
"service_net_name_or_ip", "service_net_name_or_ip",
help="Can be either name of network that is used by service " help="Can be either name of network that is used by service "
"instance within Nova to get IP address or IP address itself " "instance within Nova to get IP address or IP address itself "
"for managing shares there. " "for managing shares there. "
"Used only when share servers handling is disabled."), "Used only when share servers handling is disabled."),
cfg.StrOpt( cfg.HostAddressOpt(
"tenant_net_name_or_ip", "tenant_net_name_or_ip",
help="Can be either name of network that is used by service " help="Can be either name of network that is used by service "
"instance within Nova to get IP address or IP address itself " "instance within Nova to get IP address or IP address itself "

View File

@ -30,8 +30,8 @@ from manila.share import driver
from manila.share import utils as share_utils from manila.share import utils as share_utils
tegile_opts = [ tegile_opts = [
cfg.StrOpt('tegile_nas_server', cfg.HostAddressOpt('tegile_nas_server',
help='Tegile NAS server hostname or IP address.'), help='Tegile NAS server hostname or IP address.'),
cfg.StrOpt('tegile_nas_login', cfg.StrOpt('tegile_nas_login',
help='User name for the Tegile NAS server.'), help='User name for the Tegile NAS server.'),
cfg.StrOpt('tegile_nas_password', cfg.StrOpt('tegile_nas_password',

View File

@ -41,11 +41,11 @@ from manila import utils
zfsonlinux_opts = [ zfsonlinux_opts = [
cfg.StrOpt( cfg.HostAddressOpt(
"zfs_share_export_ip", "zfs_share_export_ip",
required=True, required=True,
help="IP to be added to user-facing export location. Required."), help="IP to be added to user-facing export location. Required."),
cfg.StrOpt( cfg.HostAddressOpt(
"zfs_service_ip", "zfs_service_ip",
required=True, required=True,
help="IP to be added to admin-facing export location. Required."), help="IP to be added to admin-facing export location. Required."),

View File

@ -30,10 +30,10 @@ from manila.share.drivers.zfssa import zfssarest
ZFSSA_OPTS = [ ZFSSA_OPTS = [
cfg.StrOpt('zfssa_host', cfg.HostAddressOpt('zfssa_host',
help='ZFSSA management IP address.'), help='ZFSSA management IP address.'),
cfg.StrOpt('zfssa_data_ip', cfg.HostAddressOpt('zfssa_data_ip',
help='IP address for data.'), help='IP address for data.'),
cfg.StrOpt('zfssa_auth_user', cfg.StrOpt('zfssa_auth_user',
help='ZFSSA management authorized username.'), help='ZFSSA management authorized username.'),
cfg.StrOpt('zfssa_auth_password', cfg.StrOpt('zfssa_auth_password',

View File

@ -38,7 +38,7 @@ class ManilaCmdShareTestCase(test.TestCase):
self.mock_object(self.launcher, 'launch_service') self.mock_object(self.launcher, 'launch_service')
self.mock_object(self.launcher, 'wait') self.mock_object(self.launcher, 'wait')
self.server = manila_share.service.Service.create.return_value self.server = manila_share.service.Service.create.return_value
fake_host = 'fake_host' fake_host = 'fake.host'
CONF.set_override('enabled_share_backends', backends, CONF.set_override('enabled_share_backends', backends,
enforce_type=True) enforce_type=True)
CONF.set_override('host', fake_host, enforce_type=True) CONF.set_override('host', fake_host, enforce_type=True)

View File

@ -60,7 +60,7 @@ class NetAppCDOTDataMotionTestCase(test.TestCase):
group=self.backend, enforce_type=True) group=self.backend, enforce_type=True)
CONF.set_override("netapp_password", "fake_password", CONF.set_override("netapp_password", "fake_password",
group=self.backend, enforce_type=True) group=self.backend, enforce_type=True)
CONF.set_override("netapp_server_hostname", "fake_hostname", CONF.set_override("netapp_server_hostname", "fake.hostname",
group=self.backend, enforce_type=True) group=self.backend, enforce_type=True)
CONF.set_override("netapp_server_port", 8866, CONF.set_override("netapp_server_port", 8866,
group=self.backend, enforce_type=True) group=self.backend, enforce_type=True)
@ -72,7 +72,7 @@ class NetAppCDOTDataMotionTestCase(test.TestCase):
data_motion.get_client_for_backend(self.backend) data_motion.get_client_for_backend(self.backend)
self.mock_cmode_client.assert_called_once_with( self.mock_cmode_client.assert_called_once_with(
hostname='fake_hostname', password='fake_password', hostname='fake.hostname', password='fake_password',
username='fake_user', transport_type='https', port=8866, username='fake_user', transport_type='https', port=8866,
trace=mock.ANY, vserver=None) trace=mock.ANY, vserver=None)
@ -86,7 +86,7 @@ class NetAppCDOTDataMotionTestCase(test.TestCase):
data_motion.get_client_for_backend(self.backend) data_motion.get_client_for_backend(self.backend)
self.mock_cmode_client.assert_called_once_with( self.mock_cmode_client.assert_called_once_with(
hostname='fake_hostname', password='fake_password', hostname='fake.hostname', password='fake_password',
username='fake_user', transport_type='https', port=8866, username='fake_user', transport_type='https', port=8866,
trace=mock.ANY, vserver='fake_vserver') trace=mock.ANY, vserver='fake_vserver')