oslo.config/oslo_config/tests/test_get_location.py
Ben Nemec 03f91cfd67 Fix get_location for opts in groups
get_location defines the type of its ``group`` parameter as a str,
but it then passes that directly into _do_get, which expects an
OptGroup for its parameter. When it tries to reference group.name
it blows up because a str doesn't have a .name attr.

In the interest of not changing either API, this change coerces the
group str into an OptGroup.

Closes-Bug: 1807230
Change-Id: Iae547cbd63059fa19691a7f7fe398b148effd177
2018-12-06 16:29:23 +00:00

206 lines
6.6 KiB
Python

# 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.
import io
import tempfile
import textwrap
from oslotest import base
from oslo_config import cfg
class TestConfigOpts(cfg.ConfigOpts):
def __call__(self, args=None, default_config_files=[],
default_config_dirs=[]):
return cfg.ConfigOpts.__call__(
self,
args=args,
prog='test',
version='1.0',
usage='%(prog)s FOO BAR',
description='somedesc',
epilog='tepilog',
default_config_files=default_config_files,
default_config_dirs=default_config_dirs,
validate_default_values=True)
class LocationTestCase(base.BaseTestCase):
def test_user_controlled(self):
self.assertTrue(cfg.Locations.user.is_user_controlled)
self.assertTrue(cfg.Locations.command_line.is_user_controlled)
def test_not_user_controlled(self):
self.assertFalse(cfg.Locations.opt_default.is_user_controlled)
self.assertFalse(cfg.Locations.set_default.is_user_controlled)
self.assertFalse(cfg.Locations.set_override.is_user_controlled)
class GetLocationTestCase(base.BaseTestCase):
def setUp(self):
super(GetLocationTestCase, self).setUp()
def _clear():
cfg._show_caller_details = False
self.addCleanup(_clear)
cfg._show_caller_details = True
self.conf = TestConfigOpts()
self.normal_opt = cfg.StrOpt(
'normal_opt',
default='normal_opt_default',
)
self.conf.register_opt(self.normal_opt)
self.cli_opt = cfg.StrOpt(
'cli_opt',
default='cli_opt_default',
)
self.conf.register_cli_opt(self.cli_opt)
self.group_opt = cfg.StrOpt(
'group_opt',
default='group_opt_default',
)
self.conf.register_opt(self.group_opt, group='group')
def test_opt_default(self):
self.conf([])
loc = self.conf.get_location('normal_opt')
self.assertEqual(
cfg.Locations.opt_default,
loc.location,
)
self.assertIn('test_get_location.py', loc.detail)
def test_set_default_on_config_opt(self):
self.conf.set_default('normal_opt', self.id())
self.conf([])
loc = self.conf.get_location('normal_opt')
self.assertEqual(
cfg.Locations.set_default,
loc.location,
)
self.assertIn('test_get_location.py', loc.detail)
def test_set_defaults_func(self):
cfg.set_defaults([self.normal_opt], normal_opt=self.id())
self.conf([])
loc = self.conf.get_location('normal_opt')
self.assertEqual(
cfg.Locations.set_default,
loc.location,
)
self.assertIn('test_get_location.py', loc.detail)
def test_set_override(self):
self.conf.set_override('normal_opt', self.id())
self.conf([])
loc = self.conf.get_location('normal_opt')
self.assertEqual(
cfg.Locations.set_override,
loc.location,
)
self.assertIn('test_get_location.py', loc.detail)
def test_user_cli(self):
filename = self._write_opt_to_tmp_file(
'DEFAULT', 'unknown_opt', self.id())
self.conf(['--config-file', filename,
'--cli_opt', 'blah'])
loc = self.conf.get_location('cli_opt')
self.assertEqual(
cfg.Locations.command_line,
loc.location,
)
def test_default_cli(self):
filename = self._write_opt_to_tmp_file(
'DEFAULT', 'unknown_opt', self.id())
self.conf(['--config-file', filename])
loc = self.conf.get_location('cli_opt')
self.assertEqual(
cfg.Locations.opt_default,
loc.location,
)
def _write_opt_to_tmp_file(self, group, option, value):
filename = tempfile.mktemp()
with io.open(filename, 'w', encoding='utf-8') as f:
f.write(textwrap.dedent(u'''
[{group}]
{option} = {value}
''').format(
group=group,
option=option,
value=value,
))
return filename
def test_user_cli_opt_in_file(self):
filename = self._write_opt_to_tmp_file(
'DEFAULT', 'cli_opt', self.id())
self.conf(['--config-file', filename])
loc = self.conf.get_location('cli_opt')
self.assertEqual(
cfg.Locations.user,
loc.location,
)
self.assertEqual(
filename,
loc.detail,
)
def test_user_file(self):
filename = self._write_opt_to_tmp_file(
'DEFAULT', 'normal_opt', self.id())
self.conf(['--config-file', filename])
loc = self.conf.get_location('normal_opt')
self.assertEqual(
cfg.Locations.user,
loc.location,
)
self.assertEqual(
filename,
loc.detail,
)
def test_duplicate_registration(self):
# NOTE(dhellmann): The ZFS driver in Cinder uses multiple Opt
# instances with the same settings but in different
# modules. We don't want to break that case with the option
# location stuff, so we need to test that it works. To
# reproduce that test we have to simulate the option being
# created in a different file, so we create a new Opt instance
# and replace its _set_location data.
dupe_opt = cfg.StrOpt(
'normal_opt',
default='normal_opt_default',
)
dupe_opt._set_location = cfg.LocationInfo(
cfg.Locations.opt_default,
'an alternative file',
)
# We expect register_opt() to return False to indicate that
# the option was already registered.
self.assertFalse(self.conf.register_opt(dupe_opt))
def test_group_opt(self):
self.conf([])
loc = self.conf.get_location('group_opt', 'group')
self.assertEqual(
cfg.Locations.opt_default,
loc.location,
)
self.assertIn('test_get_location.py', loc.detail)