diff options
author | Jenkins <jenkins@review.openstack.org> | 2016-02-15 16:49:19 +0000 |
---|---|---|
committer | Gerrit Code Review <review@openstack.org> | 2016-02-15 16:49:19 +0000 |
commit | ad69caba780ebf18d4ec8bc52bffc615aec5f92d (patch) | |
tree | 371e6c4943bc2dcc0e0440f57adef9abc08c99e3 | |
parent | 6806d14e703114f66592af52ae2c43e8dcf2f585 (diff) | |
parent | f0965c955dba16afaf350e65de2db68dc2c35c50 (diff) | |
download | keystonemiddleware-ad69caba780ebf18d4ec8bc52bffc615aec5f92d.tar.gz |
Merge "Split oslo_config and list all opts"
-rw-r--r-- | keystonemiddleware/auth_token/_opts.py | 55 | ||||
-rw-r--r-- | keystonemiddleware/opts.py | 13 | ||||
-rw-r--r-- | keystonemiddleware/tests/unit/test_opts.py | 60 | ||||
-rw-r--r-- | setup.cfg | 2 |
4 files changed, 122 insertions, 8 deletions
diff --git a/keystonemiddleware/auth_token/_opts.py b/keystonemiddleware/auth_token/_opts.py new file mode 100644 index 0000000..b1f57e9 --- /dev/null +++ b/keystonemiddleware/auth_token/_opts.py @@ -0,0 +1,55 @@ +# 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 copy + +from keystoneauth1 import loading + +import keystonemiddleware.auth_token +from keystonemiddleware.auth_token import _base + +auth_token_opts = [ + (_base.AUTHTOKEN_GROUP, + keystonemiddleware.auth_token._OPTS + + loading.get_auth_common_conf_options()) +] + +__all__ = ( + 'list_opts', +) + + +def list_opts(): + """Return a list of oslo_config options available in auth_token middleware. + + The returned list includes the non-deprecated oslo_config options which may + be registered at runtime by the project. The purpose of this is to allow + tools like the Oslo sample config file generator to discover the options + exposed to users by this middleware. + + Deprecated Options should not show up here so as to not be included in + sample configuration. + + Each element of the list is a tuple. The first element is the name of the + group under which the list of elements in the second element will be + registered. A group name of None corresponds to the [DEFAULT] group in + config files. + + This function is discoverable via the entry point + 'keystonemiddleware.auth_token' under the 'oslo.config.opts' namespace. + + :returns: a list of (group_name, opts) tuples + """ + auth_token_opts = (keystonemiddleware.auth_token._OPTS + + loading.get_auth_common_conf_options()) + + return [(_base.AUTHTOKEN_GROUP, copy.deepcopy(auth_token_opts))] diff --git a/keystonemiddleware/opts.py b/keystonemiddleware/opts.py index fad40e8..400ad76 100644 --- a/keystonemiddleware/opts.py +++ b/keystonemiddleware/opts.py @@ -21,11 +21,13 @@ import copy from keystoneauth1 import loading import keystonemiddleware.auth_token +from keystonemiddleware.auth_token import _auth from keystonemiddleware.auth_token import _base auth_token_opts = [ (_base.AUTHTOKEN_GROUP, keystonemiddleware.auth_token._OPTS + + _auth.OPTS + loading.get_auth_common_conf_options()) ] @@ -41,12 +43,13 @@ def list_auth_token_opts(): registered. A group name of None corresponds to the [DEFAULT] group in config files. - This function is also discoverable via the entry point - 'keystonemiddleware.auth_token' under the 'oslo.config.opts' - namespace. + NOTE: This function is no longer used for oslo_config sample generation. + Some services rely on this function for listing ALL (including deprecated) + options and registering them into their own config objects which we do not + want for sample config files. - The purpose of this is to allow tools like the Oslo sample config file - generator to discover the options exposed to users by this middleware. + See: :py:func:`keystonemiddleware.auth_token._opts.list_opts` for sample + config files. :returns: a list of (group_name, opts) tuples """ diff --git a/keystonemiddleware/tests/unit/test_opts.py b/keystonemiddleware/tests/unit/test_opts.py index 9cb2e84..9d9913e 100644 --- a/keystonemiddleware/tests/unit/test_opts.py +++ b/keystonemiddleware/tests/unit/test_opts.py @@ -15,18 +15,74 @@ import stevedore from testtools import matchers -from keystonemiddleware import opts +from keystonemiddleware.auth_token import _opts as new_opts +from keystonemiddleware import opts as old_opts from keystonemiddleware.tests.unit import utils class OptsTestCase(utils.TestCase): + def test_original_list_all_options(self): + result_of_old_opts = old_opts.list_auth_token_opts() + self.assertThat(result_of_old_opts, matchers.HasLength(1)) + + for group in (g for (g, _l) in result_of_old_opts): + self.assertEqual('keystone_authtoken', group) + + # This is the original list that includes deprecated options + expected_opt_names = [ + 'auth_admin_prefix', + 'auth_host', + 'auth_port', + 'auth_protocol', + 'auth_uri', + 'identity_uri', + 'auth_version', + 'delay_auth_decision', + 'http_connect_timeout', + 'http_request_max_retries', + 'admin_token', + 'admin_user', + 'admin_password', + 'admin_tenant_name', + 'cache', + 'certfile', + 'keyfile', + 'cafile', + 'region_name', + 'insecure', + 'signing_dir', + 'memcached_servers', + 'token_cache_time', + 'revocation_cache_time', + 'memcache_security_strategy', + 'memcache_secret_key', + 'memcache_use_advanced_pool', + 'memcache_pool_dead_retry', + 'memcache_pool_maxsize', + 'memcache_pool_unused_timeout', + 'memcache_pool_conn_get_timeout', + 'memcache_pool_socket_timeout', + 'include_service_catalog', + 'enforce_token_bind', + 'check_revocations_for_cached', + 'hash_algorithms', + 'auth_type', + 'auth_section', + ] + opt_names = [o.name for (g, l) in result_of_old_opts for o in l] + self.assertThat(opt_names, matchers.HasLength(len(expected_opt_names))) + + for opt in opt_names: + self.assertIn(opt, expected_opt_names) + def _test_list_auth_token_opts(self, result): self.assertThat(result, matchers.HasLength(1)) for group in (g for (g, _l) in result): self.assertEqual('keystone_authtoken', group) + # This is the sample config generator list WITHOUT deprecations expected_opt_names = [ 'auth_uri', 'auth_version', @@ -65,7 +121,7 @@ class OptsTestCase(utils.TestCase): self.assertIn(opt, expected_opt_names) def test_list_auth_token_opts(self): - self._test_list_auth_token_opts(opts.list_auth_token_opts()) + self._test_list_auth_token_opts(new_opts.list_opts()) def test_entry_point(self): em = stevedore.ExtensionManager('oslo.config.opts', @@ -28,7 +28,7 @@ setup-hooks = [entry_points] oslo.config.opts = - keystonemiddleware.auth_token = keystonemiddleware.opts:list_auth_token_opts + keystonemiddleware.auth_token = keystonemiddleware.auth_token._opts:list_opts paste.filter_factory = auth_token = keystonemiddleware.auth_token:filter_factory |