summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2013-02-09 19:00:19 +0000
committerGerrit Code Review <review@openstack.org>2013-02-09 19:00:19 +0000
commit8a0cdc5685696a604f7dd0e1ca384d05a52e5889 (patch)
treebeca0f352ce20c9a48ec4b37ed0826ab77dabf94
parent0b2c7ec9694013fa89062c3989d36a75f5b85ca2 (diff)
parentd1561505b31fce188a274dfd5125a0f73a096c07 (diff)
downloadoslo-8a0cdc5685696a604f7dd0e1ca384d05a52e5889.tar.gz
oslo-8a0cdc5685696a604f7dd0e1ca384d05a52e5889.tar.xz
oslo-8a0cdc5685696a604f7dd0e1ca384d05a52e5889.zip
Merge "Implements import_group"
-rw-r--r--openstack/common/cfg.py18
-rw-r--r--tests/testmods/baz_qux_opt.py21
-rw-r--r--tests/unit/test_cfg.py17
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):