Merge "Fix handling of deprecated opts in CLI"

This commit is contained in:
Jenkins
2014-08-20 22:01:00 +00:00
committed by Gerrit Code Review
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)