summaryrefslogtreecommitdiff
path: root/glanceclient/tests
diff options
context:
space:
mode:
authorZuul <zuul@review.openstack.org>2018-05-18 16:23:20 +0000
committerGerrit Code Review <review@openstack.org>2018-05-18 16:23:20 +0000
commit1ef5e5d16976df4b48c0925cdc6c5dc0dfbfb610 (patch)
tree6e957ff18090d5e569bcf2d5e647e5851e45a703 /glanceclient/tests
parentee029a9b927a41c028427f8afc1821ed914e6d47 (diff)
parent195add500bac78637f94a008feee986b7800968d (diff)
downloadpython-glanceclient-1ef5e5d16976df4b48c0925cdc6c5dc0dfbfb610.tar.gz
Merge "Removes unicode 'u' response from "glance image-tag-update""
Diffstat (limited to 'glanceclient/tests')
-rw-r--r--glanceclient/tests/unit/test_utils.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/glanceclient/tests/unit/test_utils.py b/glanceclient/tests/unit/test_utils.py
index cd87e21..a63ee80 100644
--- a/glanceclient/tests/unit/test_utils.py
+++ b/glanceclient/tests/unit/test_utils.py
@@ -115,6 +115,42 @@ class TestUtils(testtools.TestCase):
''',
output_dict.getvalue())
+ def test_print_list_with_list_no_unicode(self):
+ class Struct(object):
+ def __init__(self, **entries):
+ self.__dict__.update(entries)
+
+ # test for removing 'u' from lists in print_list output
+ columns = ['ID', 'Tags']
+ images = [Struct(**{'id': 'b8e1c57e-907a-4239-aed8-0df8e54b8d2d',
+ 'tags': [u'Name1', u'Tag_123', u'veeeery long']})]
+ saved_stdout = sys.stdout
+ try:
+ sys.stdout = output_list = six.StringIO()
+ utils.print_list(images, columns)
+
+ finally:
+ sys.stdout = saved_stdout
+
+ self.assertEqual('''\
++--------------------------------------+--------------------------------------+
+| ID | Tags |
++--------------------------------------+--------------------------------------+
+| b8e1c57e-907a-4239-aed8-0df8e54b8d2d | ['Name1', 'Tag_123', 'veeeery long'] |
++--------------------------------------+--------------------------------------+
+''',
+ output_list.getvalue())
+
+ def test_unicode_key_value_to_string(self):
+ src = {u'key': u'\u70fd\u7231\u5a77'}
+ expected = {'key': '\xe7\x83\xbd\xe7\x88\xb1\xe5\xa9\xb7'}
+ if six.PY2:
+ self.assertEqual(expected, utils.unicode_key_value_to_string(src))
+ else:
+ # u'xxxx' in PY3 is str, we will not get extra 'u' from cli
+ # output in PY3
+ self.assertEqual(src, utils.unicode_key_value_to_string(src))
+
def test_schema_args_with_list_types(self):
# NOTE(flaper87): Regression for bug
# https://bugs.launchpad.net/python-glanceclient/+bug/1401032