summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorDean Troyer <dtroyer@gmail.com>2013-04-11 16:45:34 -0500
committerDean Troyer <dtroyer@gmail.com>2013-05-24 15:02:52 -0500
commitea9ec1c6bc00ee90b288808f6d48d2ed420cf4b5 (patch)
treeebc515780d24cbbb46fd3c27fa6d30fbd4c894e5 /tests
parentd49fcb726d078b25566e57c7604d0d52d9998b22 (diff)
downloadpython-openstackclient-ea9ec1c6bc00ee90b288808f6d48d2ed420cf4b5.tar.gz
Tweak volume commands and add k=v argparse action
Basic cleanups: * change metadata to property * add new KeyValueAction to parse the property options * multiple properties can be set using multiple --property args * consistent formatting * do lookups for volume args Change-Id: Ib6c43f01ad46b395aee8c61e886f42e2a5f5573e
Diffstat (limited to 'tests')
-rw-r--r--tests/common/test_parseractions.py104
1 files changed, 104 insertions, 0 deletions
diff --git a/tests/common/test_parseractions.py b/tests/common/test_parseractions.py
new file mode 100644
index 00000000..f48c4d72
--- /dev/null
+++ b/tests/common/test_parseractions.py
@@ -0,0 +1,104 @@
+# Copyright 2012-2013 OpenStack Foundation
+#
+# 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 argparse
+
+from openstackclient.common import parseractions
+from tests import utils
+
+
+class TestKeyValueAction(utils.TestCase):
+ def test_good_values(self):
+ parser = argparse.ArgumentParser()
+
+ # Set up our typical usage
+ parser.add_argument(
+ '--property',
+ metavar='<key=value>',
+ action=parseractions.KeyValueAction,
+ help='Property to store for this volume '
+ '(repeat option to set multiple properties)',
+ )
+
+ results = parser.parse_args([
+ '--property', 'red=',
+ '--property', 'green=100%',
+ '--property', 'blue=50%',
+ ])
+
+ actual = getattr(results, 'property', {})
+ # All should pass through unmolested
+ expect = {'red': '', 'green': '100%', 'blue': '50%'}
+ self.assertDictEqual(expect, actual)
+
+ def test_default_values(self):
+ parser = argparse.ArgumentParser()
+
+ # Set up our typical usage
+ parser.add_argument(
+ '--property',
+ metavar='<key=value>',
+ action=parseractions.KeyValueAction,
+ default={'green': '20%', 'format': '#rgb'},
+ help='Property to store for this volume '
+ '(repeat option to set multiple properties)',
+ )
+
+ results = parser.parse_args([
+ '--property', 'red=',
+ '--property', 'green=100%',
+ '--property', 'blue=50%',
+ ])
+
+ actual = getattr(results, 'property', {})
+ # Verify green default is changed, format default is unchanged
+ expect = {'red': '', 'green': '100%', 'blue': '50%', 'format': '#rgb'}
+ self.assertDictEqual(expect, actual)
+
+ def test_error_values(self):
+ parser = argparse.ArgumentParser()
+
+ # Set up our typical usage
+ parser.add_argument(
+ '--property',
+ metavar='<key=value>',
+ action=parseractions.KeyValueAction,
+ default={'green': '20%', 'blue': '40%'},
+ help='Property to store for this volume '
+ '(repeat option to set multiple properties)',
+ )
+
+ results = parser.parse_args([
+ '--property', 'red',
+ '--property', 'green=100%',
+ '--property', 'blue',
+ ])
+
+ failhere = None
+ actual = getattr(results, 'property', {})
+ # Verify non-existant red key
+ try:
+ failhere = actual['red']
+ except Exception as e:
+ self.assertTrue(type(e) == KeyError)
+ # Verify removal of blue key
+ try:
+ failhere = actual['blue']
+ except Exception as e:
+ self.assertTrue(type(e) == KeyError)
+ # There should be no red or blue
+ expect = {'green': '100%'}
+ self.assertDictEqual(expect, actual)
+ self.assertEqual(failhere, None)