Fix handling of deprecated opts in CLI

Deprecated opts are supposed to be accessible via the CLI in a similar
way as they are available via CONF. Currently these values are ignored.

Add CLI flags for all the deprecated opts as well.

Change-Id: If5f23c7b30a0cacda893a5e3150bc6bdb95f3693
This commit is contained in:
Jamie Lennox
2014-08-13 21:57:34 +10:00
parent 68079595e7
commit c751526ae8
2 changed files with 68 additions and 6 deletions

View File

@@ -141,13 +141,20 @@ class BaseAuthPlugin(object):
# transition. # transition.
for opt in cls.get_options(): for opt in cls.get_options():
if opt.default is None: args = []
env_name = opt.name.replace('-', '_').upper() envs = []
default = os.environ.get('OS_' + env_name)
else:
default = opt.default
parser.add_argument('--os-' + opt.name, for o in [opt] + opt.deprecated_opts:
args.append('--os-%s' % o.name)
envs.append('OS_%s' % o.name.replace('-', '_').upper())
default = opt.default
if default is None:
# select the first ENV that is not false-y or return None
env_vars = (os.environ.get(e) for e in envs)
default = six.next(six.moves.filter(None, env_vars), None)
parser.add_argument(*args,
default=default, default=default,
metavar=opt.metavar, metavar=opt.metavar,
help=opt.help, help=opt.help,

View File

@@ -13,10 +13,30 @@
import argparse import argparse
import uuid import uuid
import mock
from oslo.config import cfg
from keystoneclient.auth import base
from keystoneclient.auth import cli from keystoneclient.auth import cli
from keystoneclient.tests.auth import utils from keystoneclient.tests.auth import utils
class TesterPlugin(base.BaseAuthPlugin):
def get_token(self, *args, **kwargs):
return None
@classmethod
def get_options(cls):
# NOTE(jamielennox): this is kind of horrible. If you specify this as
# a deprecated_name= value it will convert - to _ which is not what we
# want for a CLI option.
deprecated = [cfg.DeprecatedOpt('test-other')]
return [
cfg.StrOpt('test-opt', help='tester', deprecated_opts=deprecated)
]
class CliTests(utils.TestCase): class CliTests(utils.TestCase):
def setUp(self): def setUp(self):
@@ -83,3 +103,38 @@ class CliTests(utils.TestCase):
self.assertEqual(self.a_float, a['a_float']) self.assertEqual(self.a_float, a['a_float'])
self.assertEqual(3, a['a_int']) self.assertEqual(3, a['a_int'])
def test_deprecated_cli_options(self):
TesterPlugin.register_argparse_arguments(self.p)
val = uuid.uuid4().hex
opts = self.p.parse_args(['--os-test-other', val])
self.assertEqual(val, opts.os_test_opt)
def test_deprecated_multi_cli_options(self):
TesterPlugin.register_argparse_arguments(self.p)
val1 = uuid.uuid4().hex
val2 = uuid.uuid4().hex
# argarse rules say that the last specified wins.
opts = self.p.parse_args(['--os-test-other', val2,
'--os-test-opt', val1])
self.assertEqual(val1, opts.os_test_opt)
def test_deprecated_env_options(self):
val = uuid.uuid4().hex
with mock.patch.dict('os.environ', {'OS_TEST_OTHER': val}):
TesterPlugin.register_argparse_arguments(self.p)
opts = self.p.parse_args([])
self.assertEqual(val, opts.os_test_opt)
def test_deprecated_env_multi_options(self):
val1 = uuid.uuid4().hex
val2 = uuid.uuid4().hex
with mock.patch.dict('os.environ', {'OS_TEST_OPT': val1,
'OS_TEST_OTHER': val2}):
TesterPlugin.register_argparse_arguments(self.p)
opts = self.p.parse_args([])
self.assertEqual(val1, opts.os_test_opt)