diff options
| author | Zhongyue Luo <zhongyue.nah@intel.com> | 2013-01-30 22:27:51 +0800 |
|---|---|---|
| committer | Zhongyue Luo <zhongyue.nah@intel.com> | 2013-01-31 06:19:25 +0800 |
| commit | d1561505b31fce188a274dfd5125a0f73a096c07 (patch) | |
| tree | 224b8918bd0748fb07b492c36569abb0ba752607 | |
| parent | c29263c4a81d2e71a3d6e36eb32e5df9d2c8fb05 (diff) | |
| download | oslo-d1561505b31fce188a274dfd5125a0f73a096c07.tar.gz oslo-d1561505b31fce188a274dfd5125a0f73a096c07.tar.xz oslo-d1561505b31fce188a274dfd5125a0f73a096c07.zip | |
Implements import_group
Created import_group method in cfg.py
Added testcases
Fixes bug #1107843
Change-Id: I427d4069dacbb6e586687370adbb08b5d50f7b63
| -rw-r--r-- | openstack/common/cfg.py | 18 | ||||
| -rw-r--r-- | tests/testmods/baz_qux_opt.py | 21 | ||||
| -rw-r--r-- | tests/unit/test_cfg.py | 17 |
3 files changed, 56 insertions, 0 deletions
diff --git a/openstack/common/cfg.py b/openstack/common/cfg.py index 527a5a5..a9407b4 100644 --- a/openstack/common/cfg.py +++ b/openstack/common/cfg.py @@ -1297,6 +1297,24 @@ class ConfigOpts(collections.Mapping): __import__(module_str) self._get_opt_info(name, group) + def import_group(self, group, module_str): + """Import an option group from a module. + + Import a module and check that a given option group is registered. + + This is intended for use with global configuration objects + like cfg.CONF where modules commonly register options with + CONF at module load time. If one module requires an option group + defined by another module it can use this method to explicitly + declare the dependency. + + :param group: an option OptGroup object or group name + :param module_str: the name of a module to import + :raises: ImportError, NoSuchGroupError + """ + __import__(module_str) + self._get_group(group) + @__clear_cache def set_override(self, name, override, group=None): """Override an opt value. diff --git a/tests/testmods/baz_qux_opt.py b/tests/testmods/baz_qux_opt.py new file mode 100644 index 0000000..b2c7ecb --- /dev/null +++ b/tests/testmods/baz_qux_opt.py @@ -0,0 +1,21 @@ +# vim: tabstop=4 shiftwidth=4 softtabstop=4 + +# Copyright (c) 2013 Intel Corporation. +# +# 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. + +from openstack.common import cfg + +CONF = cfg.CONF + +CONF.register_opt(cfg.StrOpt('baz'), group='qux') diff --git a/tests/unit/test_cfg.py b/tests/unit/test_cfg.py index 07de853..7b6123c 100644 --- a/tests/unit/test_cfg.py +++ b/tests/unit/test_cfg.py @@ -1241,6 +1241,23 @@ class ImportOptTestCase(BaseTestCase): 'blaa', 'tests.testmods.blaa_opt', group='blaa') +class ImportGroupTestCase(BaseTestCase): + + def test_import_group(self): + self.assertFalse(hasattr(CONF, 'qux')) + CONF.import_group('qux', 'tests.testmods.baz_qux_opt') + self.assertTrue(hasattr(CONF, 'qux')) + self.assertTrue(hasattr(CONF.qux, 'baz')) + + def test_import_group_import_error(self): + self.assertRaises(ImportError, CONF.import_group, + 'qux', 'tests.testmods.bazzz_quxxx_opt') + + def test_import_group_no_such_group(self): + self.assertRaises(NoSuchGroupError, CONF.import_group, + 'quxxx', 'tests.testmods.baz_qux_opt') + + class RequiredOptsTestCase(BaseTestCase): def setUp(self): |
