Merge "Add choices option to several options"

This commit is contained in:
Jenkins 2016-01-28 05:43:58 +00:00 committed by Gerrit Code Review
commit 454c96156d
12 changed files with 71 additions and 23 deletions

View File

@ -30,6 +30,7 @@ api_opts = [
cfg.StrOpt( cfg.StrOpt(
'auth_strategy', 'auth_strategy',
default='keystone', default='keystone',
choices=['noauth', 'keystone'],
help=_('Authentication strategy used by ironic-api: one of "keystone" ' help=_('Authentication strategy used by ironic-api: one of "keystone" '
'or "noauth". "noauth" should not be used in a production ' 'or "noauth". "noauth" should not be used in a production '
'environment because all authentication will be disabled.')), 'environment because all authentication will be disabled.')),

View File

@ -51,6 +51,7 @@ glance_opts = [
help=_('Default glance port.')), help=_('Default glance port.')),
cfg.StrOpt('glance_protocol', cfg.StrOpt('glance_protocol',
default='http', default='http',
choices=['http', 'https'],
help=_('Default protocol to use when connecting to glance. ' help=_('Default protocol to use when connecting to glance. '
'Set to https for SSL.')), 'Set to https for SSL.')),
cfg.ListOpt('glance_api_servers', cfg.ListOpt('glance_api_servers',
@ -67,6 +68,7 @@ glance_opts = [
'glance.')), 'glance.')),
cfg.StrOpt('auth_strategy', cfg.StrOpt('auth_strategy',
default='keystone', default='keystone',
choices=['keystone', 'noauth'],
help=_('Authentication strategy to use when connecting to ' help=_('Authentication strategy to use when connecting to '
'glance. Only "keystone" and "noauth" are currently ' 'glance. Only "keystone" and "noauth" are currently '
'supported by ironic.')), 'supported by ironic.')),

View File

@ -44,6 +44,7 @@ neutron_opts = [
help=_('Client retries in the case of a failed request.')), help=_('Client retries in the case of a failed request.')),
cfg.StrOpt('auth_strategy', cfg.StrOpt('auth_strategy',
default='keystone', default='keystone',
choices=['keystone', 'noauth'],
help=_('Default authentication strategy to use when connecting ' help=_('Default authentication strategy to use when connecting '
'to neutron. Can be either "keystone" or "noauth". ' 'to neutron. Can be either "keystone" or "noauth". '
'Running neutron in noauth mode (related to but not ' 'Running neutron in noauth mode (related to but not '

View File

@ -50,6 +50,7 @@ COMMON_PROPERTIES.update(OPTIONAL_PROPERTIES)
opts = [ opts = [
cfg.StrOpt('protocol', cfg.StrOpt('protocol',
default='http', default='http',
choices=['http', 'https'],
help=_('Protocol used for AMT endpoint, ' help=_('Protocol used for AMT endpoint, '
'support http/https')), 'support http/https')),
cfg.IntOpt('awake_interval', cfg.IntOpt('awake_interval',

View File

@ -57,6 +57,8 @@ opts = [
help=_('IP of remote image server')), help=_('IP of remote image server')),
cfg.StrOpt('remote_image_share_type', cfg.StrOpt('remote_image_share_type',
default='CIFS', default='CIFS',
choices=['CIFS', 'NFS'],
ignore_case=True,
help=_('Share type of virtual media, either "NFS" or "CIFS"')), help=_('Share type of virtual media, either "NFS" or "CIFS"')),
cfg.StrOpt('remote_image_share_name', cfg.StrOpt('remote_image_share_name',
default='share', default='share',
@ -81,8 +83,6 @@ REQUIRED_PROPERTIES = {
COMMON_PROPERTIES = REQUIRED_PROPERTIES COMMON_PROPERTIES = REQUIRED_PROPERTIES
SUPPORTED_SHARE_TYPES = ('nfs', 'cifs')
def _parse_config_option(): def _parse_config_option():
"""Parse config file options. """Parse config file options.
@ -97,11 +97,6 @@ def _parse_config_option():
_("Value '%s' for remote_image_share_root isn't a directory " _("Value '%s' for remote_image_share_root isn't a directory "
"or doesn't exist.") % "or doesn't exist.") %
CONF.irmc.remote_image_share_root) CONF.irmc.remote_image_share_root)
if CONF.irmc.remote_image_share_type.lower() not in SUPPORTED_SHARE_TYPES:
error_msgs.append(
_("Value '%s' for remote_image_share_type is not supported "
"value either 'NFS' or 'CIFS'.") %
CONF.irmc.remote_image_share_type)
if error_msgs: if error_msgs:
msg = (_("The following errors were encountered while parsing " msg = (_("The following errors were encountered while parsing "
"config file:%s") % error_msgs) "config file:%s") % error_msgs)

View File

@ -27,10 +27,12 @@ scci = importutils.try_import('scciclient.irmc.scci')
opts = [ opts = [
cfg.PortOpt('port', cfg.PortOpt('port',
default=443, default=443,
choices=[443, 80],
help=_('Port to be used for iRMC operations, either 80 or ' help=_('Port to be used for iRMC operations, either 80 or '
'443')), '443')),
cfg.StrOpt('auth_method', cfg.StrOpt('auth_method',
default='basic', default='basic',
choices=['basic', 'digest'],
help=_('Authentication method to be used for iRMC operations, ' help=_('Authentication method to be used for iRMC operations, '
'either "basic" or "digest"')), 'either "basic" or "digest"')),
cfg.IntOpt('client_timeout', cfg.IntOpt('client_timeout',
@ -38,6 +40,7 @@ opts = [
help=_('Timeout (in seconds) for iRMC operations')), help=_('Timeout (in seconds) for iRMC operations')),
cfg.StrOpt('sensor_method', cfg.StrOpt('sensor_method',
default='ipmitool', default='ipmitool',
choices=['ipmitool', 'scci'],
help=_('Sensor data retrieval method, either ' help=_('Sensor data retrieval method, either '
'"ipmitool" or "scci"')), '"ipmitool" or "scci"')),
] ]

View File

@ -15,6 +15,7 @@ import os
import shutil import shutil
import mock import mock
from oslo_config import cfg
import requests import requests
import sendfile import sendfile
import six import six
@ -330,3 +331,13 @@ class ServiceGetterTestCase(base.TestCase):
image_href = 'usenet://alt.binaries.dvd/image.qcow2' image_href = 'usenet://alt.binaries.dvd/image.qcow2'
self.assertRaises(exception.ImageRefValidationFailed, self.assertRaises(exception.ImageRefValidationFailed,
image_service.get_image_service, image_href) image_service.get_image_service, image_href)
def test_out_range_auth_strategy(self):
self.assertRaises(ValueError, cfg.CONF.set_override,
'auth_strategy', 'fake', 'glance',
enforce_type=True)
def test_out_range_glance_protocol(self):
self.assertRaises(ValueError, cfg.CONF.set_override,
'glance_protocol', 'fake', 'glance',
enforce_type=True)

View File

@ -15,8 +15,10 @@
# under the License. # under the License.
import mock import mock
from neutronclient.common import exceptions as neutron_client_exc from neutronclient.common import exceptions as neutron_client_exc
from neutronclient.v2_0 import client from neutronclient.v2_0 import client
from oslo_config import cfg
from oslo_utils import uuidutils from oslo_utils import uuidutils
from ironic.common import dhcp_factory from ironic.common import dhcp_factory
@ -63,13 +65,6 @@ class TestNeutron(db_base.DbTestCase):
dhcp_factory.DHCPFactory._dhcp_provider = None dhcp_factory.DHCPFactory._dhcp_provider = None
def test__build_client_invalid_auth_strategy(self):
self.config(auth_strategy='wrong_config', group='neutron')
token = 'test-token-123'
self.assertRaises(exception.ConfigInvalid,
neutron._build_client,
token=token)
@mock.patch.object(client.Client, "__init__") @mock.patch.object(client.Client, "__init__")
def test__build_client_with_token(self, mock_client_init): def test__build_client_with_token(self, mock_client_init):
token = 'test-token-123' token = 'test-token-123'
@ -487,3 +482,8 @@ class TestNeutron(db_base.DbTestCase):
list_mock.assert_called_once_with( list_mock.assert_called_once_with(
network_id='00000000-0000-0000-0000-000000000000') network_id='00000000-0000-0000-0000-000000000000')
delete_mock.assert_called_once_with(self.neutron_port['id']) delete_mock.assert_called_once_with(self.neutron_port['id'])
def test_out_range_auth_strategy(self):
self.assertRaises(ValueError, cfg.CONF.set_override,
'auth_strategy', 'fake', 'neutron',
enforce_type=True)

View File

@ -209,3 +209,8 @@ class AwakeAMTInterfaceTestCase(db_base.DbTestCase):
CONF.set_override('awake_interval', 0, 'amt') CONF.set_override('awake_interval', 0, 'amt')
amt_common.awake_amt_interface(self.node) amt_common.awake_amt_interface(self.node)
self.assertFalse(mock_ex.called) self.assertFalse(mock_ex.called)
def test_out_range_protocol(self):
self.assertRaises(ValueError, cfg.CONF.set_override,
'protocol', 'fake', 'amt',
enforce_type=True)

View File

@ -87,15 +87,6 @@ class IRMCDeployPrivateMethodsTestCase(db_base.DbTestCase):
irmc_boot._parse_config_option) irmc_boot._parse_config_option)
isdir_mock.assert_called_once_with('/non_existed_root') isdir_mock.assert_called_once_with('/non_existed_root')
@mock.patch.object(os.path, 'isdir', spec_set=True, autospec=True)
def test__parse_config_option_wrong_share_type(self, isdir_mock):
CONF.irmc.remote_image_share_type = 'NTFS'
isdir_mock.return_value = True
self.assertRaises(exception.InvalidParameterValue,
irmc_boot._parse_config_option)
isdir_mock.assert_called_once_with('/remote_image_share_root')
@mock.patch.object(os.path, 'isfile', spec_set=True, autospec=True) @mock.patch.object(os.path, 'isfile', spec_set=True, autospec=True)
def test__parse_driver_info_in_share(self, isfile_mock): def test__parse_driver_info_in_share(self, isfile_mock):
"""With required 'irmc_deploy_iso' in share.""" """With required 'irmc_deploy_iso' in share."""
@ -1029,3 +1020,12 @@ class IRMCVirtualMediaBootTestCase(db_base.DbTestCase):
task, 'boot.iso') task, 'boot.iso')
node_set_boot_device.assert_called_once_with( node_set_boot_device.assert_called_once_with(
task, boot_devices.CDROM, persistent=True) task, boot_devices.CDROM, persistent=True)
def test_remote_image_share_type_values(self):
cfg.CONF.set_override('remote_image_share_type', 'cifs', 'irmc',
enforce_type=True)
cfg.CONF.set_override('remote_image_share_type', 'nfs', 'irmc',
enforce_type=True)
self.assertRaises(ValueError, cfg.CONF.set_override,
'remote_image_share_type', 'fake', 'irmc',
enforce_type=True)

View File

@ -18,6 +18,8 @@ Test class for common methods used by iRMC modules.
import mock import mock
from oslo_config import cfg
from ironic.common import exception from ironic.common import exception
from ironic.conductor import task_manager from ironic.conductor import task_manager
from ironic.drivers.modules.irmc import common as irmc_common from ironic.drivers.modules.irmc import common as irmc_common
@ -166,3 +168,15 @@ class IRMCCommonMethodsTestCase(db_base.DbTestCase):
auth_method=self.info['irmc_auth_method'], auth_method=self.info['irmc_auth_method'],
client_timeout=self.info['irmc_client_timeout']) client_timeout=self.info['irmc_client_timeout'])
self.assertEqual('get_report', returned_mock_scci_get_report) self.assertEqual('get_report', returned_mock_scci_get_report)
def test_out_range_port(self):
self.assertRaises(ValueError, cfg.CONF.set_override,
'port', 60, 'irmc', enforce_type=True)
def test_out_range_auth_method(self):
self.assertRaises(ValueError, cfg.CONF.set_override,
'auth_method', 'fake', 'irmc', enforce_type=True)
def test_out_range_sensor_method(self):
self.assertRaises(ValueError, cfg.CONF.set_override,
'sensor_method', 'fake', 'irmc', enforce_type=True)

View File

@ -0,0 +1,15 @@
---
upgrade:
- Add ``choices`` parameter to config options. Invalid values will be
rejected when first accessing them, which can happen in the middle of
deployment.
* [DEFAULT]/auth_strategy [keystone, noauth]
* [glance]/auth_strategy [keystone, noauth]
* [glance]/glance_protocol [http, https]
* [neutron]/auth_strategy [keystone, noauth]
* [amt]/protocol [http, https]
* [irmc]/remote_image_share_type [CIFS, NFS]
* [irmc]/port [443, 80]
* [irmc]/auth_method [basic, digest]
* [irmc]/sensor_method [ipmitool, scci]