Error handling for KeyValueAction class.
The set --property command requires that the input match the "key=value" type, but if the type don't match, the return value will be None, and the command still can be implemented successfully, this may confuse the users. I think we should raise exception if the argument type don't match "key=value". So I make some changes in KeyValueAction class in this patch. Change-Id: If4a00ae6da08bc12362ef2fc82012b42839141f0
This commit is contained in:
parent
619859009a
commit
876d81ef21
@ -35,7 +35,9 @@ class KeyValueAction(argparse.Action):
|
|||||||
if '=' in values:
|
if '=' in values:
|
||||||
getattr(namespace, self.dest, {}).update([values.split('=', 1)])
|
getattr(namespace, self.dest, {}).update([values.split('=', 1)])
|
||||||
else:
|
else:
|
||||||
getattr(namespace, self.dest, {}).pop(values, None)
|
msg = _("Expected 'key=value' type, "
|
||||||
|
"but got: %s") % (str(values))
|
||||||
|
raise argparse.ArgumentTypeError(msg)
|
||||||
|
|
||||||
|
|
||||||
class MultiKeyValueAction(argparse.Action):
|
class MultiKeyValueAction(argparse.Action):
|
||||||
|
@ -49,16 +49,13 @@ class TestKeyValueAction(utils.TestCase):
|
|||||||
self.assertDictEqual(expect, actual)
|
self.assertDictEqual(expect, actual)
|
||||||
|
|
||||||
def test_error_values(self):
|
def test_error_values(self):
|
||||||
results = self.parser.parse_args([
|
self.assertRaises(
|
||||||
|
argparse.ArgumentTypeError,
|
||||||
|
self.parser.parse_args,
|
||||||
|
[
|
||||||
'--property', 'red',
|
'--property', 'red',
|
||||||
'--property', 'green=100%',
|
]
|
||||||
'--property', 'blue',
|
)
|
||||||
])
|
|
||||||
|
|
||||||
actual = getattr(results, 'property', {})
|
|
||||||
# There should be no red or blue
|
|
||||||
expect = {'green': '100%', 'format': '#rgb'}
|
|
||||||
self.assertDictEqual(expect, actual)
|
|
||||||
|
|
||||||
|
|
||||||
class TestMultiKeyValueAction(utils.TestCase):
|
class TestMultiKeyValueAction(utils.TestCase):
|
||||||
|
Loading…
Reference in New Issue
Block a user