Remove unicode-related Python2-only code

This commit:
- removes the old "u" prefix from all strings
- removes the unicode_key_value_to_string function

Change-Id: I1da347e31e828fd2359f0935a4da47257116d4cb
This commit is contained in:
Cyril Roelandt
2022-09-13 16:15:13 +02:00
parent a3f13bdcb4
commit fc8f9ac2ed
8 changed files with 32 additions and 61 deletions

View File

@@ -57,7 +57,7 @@ master_doc = 'index'
# General information about the project. # General information about the project.
project = 'python-glanceclient' project = 'python-glanceclient'
copyright = u'OpenStack Foundation' copyright = 'OpenStack Foundation'
# If true, '()' will be appended to :func: etc. cross-reference text. # If true, '()' will be appended to :func: etc. cross-reference text.
add_function_parentheses = True add_function_parentheses = True
@@ -83,8 +83,8 @@ htmlhelp_basename = '%sdoc' % project
# -- Options for man page output ---------------------------------------------- # -- Options for man page output ----------------------------------------------
# Grouping the document tree for man pages. # Grouping the document tree for man pages.
# List of tuples 'sourcefile', 'target', u'title', u'Authors name', 'manual' # List of tuples 'sourcefile', 'target', 'title', 'Authors name', 'manual'
man_pages = [ man_pages = [
('cli/glance', 'glance', u'Client for OpenStack Images API', ('cli/glance', 'glance', 'Client for OpenStack Images API',
[u'OpenStack Foundation'], 1), ['OpenStack Foundation'], 1),
] ]

View File

@@ -269,34 +269,11 @@ def print_list(objs, fields, formatters=None, field_settings=None):
field_name = field.lower().replace(' ', '_') field_name = field.lower().replace(' ', '_')
data = getattr(o, field_name, None) or '' data = getattr(o, field_name, None) or ''
row.append(data) row.append(data)
count = 0
# Converts unicode values in list to string
for part in row:
count = count + 1
if isinstance(part, list):
part = unicode_key_value_to_string(part)
row[count - 1] = part
pt.add_row(row) pt.add_row(row)
print(encodeutils.safe_decode(pt.get_string())) print(encodeutils.safe_decode(pt.get_string()))
def _encode(src):
"""remove extra 'u' in PY2."""
return src
def unicode_key_value_to_string(src):
"""Recursively converts dictionary keys to strings."""
if isinstance(src, dict):
return dict((_encode(k),
_encode(unicode_key_value_to_string(v)))
for k, v in src.items())
if isinstance(src, list):
return [unicode_key_value_to_string(l) for l in src]
return _encode(src)
def print_dict(d, max_column_width=80): def print_dict(d, max_column_width=80):
pt = prettytable.PrettyTable(['Property', 'Value'], caching=False) pt = prettytable.PrettyTable(['Property', 'Value'], caching=False)
pt.align = 'l' pt.align = 'l'

View File

@@ -66,7 +66,7 @@ class TestClient(testtools.TestCase):
self.endpoint = 'http://example.com:9292' self.endpoint = 'http://example.com:9292'
self.ssl_endpoint = 'https://example.com:9292' self.ssl_endpoint = 'https://example.com:9292'
self.token = u'abc123' self.token = 'abc123'
self.client = getattr(self, self.create_client)() self.client = getattr(self, self.create_client)()
@@ -80,7 +80,7 @@ class TestClient(testtools.TestCase):
'X-Service-Catalog': 'service_catalog', 'X-Service-Catalog': 'service_catalog',
} }
# with token # with token
kwargs = {'token': u'fake-token', kwargs = {'token': 'fake-token',
'identity_headers': identity_headers} 'identity_headers': identity_headers}
http_client_object = http.HTTPClient(self.endpoint, **kwargs) http_client_object = http.HTTPClient(self.endpoint, **kwargs)
self.assertEqual('auth_token', http_client_object.auth_token) self.assertEqual('auth_token', http_client_object.auth_token)
@@ -96,10 +96,10 @@ class TestClient(testtools.TestCase):
'X-Service-Catalog': 'service_catalog', 'X-Service-Catalog': 'service_catalog',
} }
# without X-Auth-Token in identity headers # without X-Auth-Token in identity headers
kwargs = {'token': u'fake-token', kwargs = {'token': 'fake-token',
'identity_headers': identity_headers} 'identity_headers': identity_headers}
http_client_object = http.HTTPClient(self.endpoint, **kwargs) http_client_object = http.HTTPClient(self.endpoint, **kwargs)
self.assertEqual(u'fake-token', http_client_object.auth_token) self.assertEqual('fake-token', http_client_object.auth_token)
self.assertTrue(http_client_object.identity_headers. self.assertTrue(http_client_object.identity_headers.
get('X-Auth-Token') is None) get('X-Auth-Token') is None)
@@ -210,12 +210,12 @@ class TestClient(testtools.TestCase):
self.mock.get(self.endpoint + path, text=text, self.mock.get(self.endpoint + path, text=text,
headers={"Content-Type": "text/plain"}) headers={"Content-Type": "text/plain"})
headers = {"test": u'ni\xf1o'} headers = {"test": 'ni\xf1o'}
resp, body = self.client.get(path, headers=headers) resp, body = self.client.get(path, headers=headers)
self.assertEqual(text, resp.text) self.assertEqual(text, resp.text)
def test_headers_encoding(self): def test_headers_encoding(self):
value = u'ni\xf1o' value = 'ni\xf1o'
fake_location = b'http://web_server:80/images/fake.img' fake_location = b'http://web_server:80/images/fake.img'
headers = {"test": value, headers = {"test": value,
"none-val": None, "none-val": None,
@@ -262,7 +262,7 @@ class TestClient(testtools.TestCase):
ksarqh = mock_ksarq.call_args[1]['headers'] ksarqh = mock_ksarq.call_args[1]['headers']
# Only one Content-Type header (of any text-type) # Only one Content-Type header (of any text-type)
self.assertEqual(1, [encodeutils.safe_decode(key) self.assertEqual(1, [encodeutils.safe_decode(key)
for key in ksarqh.keys()].count(u'Content-Type')) for key in ksarqh.keys()].count('Content-Type'))
# And it's the one we set # And it's the one we set
self.assertEqual(b"application/openstack-images-v2.1-json-patch", self.assertEqual(b"application/openstack-images-v2.1-json-patch",
ksarqh[b"Content-Type"]) ksarqh[b"Content-Type"])
@@ -295,7 +295,7 @@ class TestClient(testtools.TestCase):
def test_parse_endpoint(self): def test_parse_endpoint(self):
endpoint = 'http://example.com:9292' endpoint = 'http://example.com:9292'
test_client = http.HTTPClient(endpoint, token=u'adc123') test_client = http.HTTPClient(endpoint, token='adc123')
actual = test_client.parse_endpoint(endpoint) actual = test_client.parse_endpoint(endpoint)
expected = parse.SplitResult(scheme='http', expected = parse.SplitResult(scheme='http',
netloc='example.com:9292', path='', netloc='example.com:9292', path='',
@@ -304,7 +304,7 @@ class TestClient(testtools.TestCase):
def test_get_connections_kwargs_http(self): def test_get_connections_kwargs_http(self):
endpoint = 'http://example.com:9292' endpoint = 'http://example.com:9292'
test_client = http.HTTPClient(endpoint, token=u'adc123') test_client = http.HTTPClient(endpoint, token='adc123')
self.assertEqual(600.0, test_client.timeout) self.assertEqual(600.0, test_client.timeout)
def test__chunk_body_exact_size_chunk(self): def test__chunk_body_exact_size_chunk(self):
@@ -321,7 +321,7 @@ class TestClient(testtools.TestCase):
path = '/v1/images/' path = '/v1/images/'
self.mock.post(self.endpoint + path, text=text) self.mock.post(self.endpoint + path, text=text)
headers = {"test": u'chunked_request'} headers = {"test": 'chunked_request'}
resp, body = self.client.post(path, headers=headers, data=data) resp, body = self.client.post(path, headers=headers, data=data)
self.assertIsInstance(self.mock.last_request.body, types.GeneratorType) self.assertIsInstance(self.mock.last_request.body, types.GeneratorType)
self.assertEqual(text, resp.text) self.assertEqual(text, resp.text)
@@ -332,7 +332,7 @@ class TestClient(testtools.TestCase):
text = 'OK' text = 'OK'
self.mock.post(self.endpoint + path, text=text) self.mock.post(self.endpoint + path, text=text)
headers = {"test": u'chunked_request'} headers = {"test": 'chunked_request'}
resp, body = self.client.post(path, headers=headers, data=data) resp, body = self.client.post(path, headers=headers, data=data)
self.assertEqual(text, resp.text) self.assertEqual(text, resp.text)
@@ -487,7 +487,7 @@ class TestClient(testtools.TestCase):
headers = self.mock.last_request.headers headers = self.mock.last_request.headers
self.assertEqual(refreshed_token, headers['X-Auth-Token']) self.assertEqual(refreshed_token, headers['X-Auth-Token'])
# regression check for bug 1448080 # regression check for bug 1448080
unicode_token = u'ni\xf1o+==' unicode_token = 'ni\xf1o+=='
http_client.auth_token = unicode_token http_client.auth_token = unicode_token
http_client.get(path) http_client.get(path)
headers = self.mock.last_request.headers headers = self.mock.last_request.headers

View File

@@ -122,7 +122,7 @@ class TestUtils(testtools.TestCase):
# test for removing 'u' from lists in print_list output # test for removing 'u' from lists in print_list output
columns = ['ID', 'Tags'] columns = ['ID', 'Tags']
images = [Struct(**{'id': 'b8e1c57e-907a-4239-aed8-0df8e54b8d2d', images = [Struct(**{'id': 'b8e1c57e-907a-4239-aed8-0df8e54b8d2d',
'tags': [u'Name1', u'Tag_123', u'veeeery long']})] 'tags': ['Name1', 'Tag_123', 'veeeery long']})]
saved_stdout = sys.stdout saved_stdout = sys.stdout
try: try:
sys.stdout = output_list = io.StringIO() sys.stdout = output_list = io.StringIO()
@@ -178,12 +178,6 @@ class TestUtils(testtools.TestCase):
''', ''',
output_list.getvalue()) output_list.getvalue())
def test_unicode_key_value_to_string(self):
src = {u'key': u'\u70fd\u7231\u5a77'}
# 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): def test_schema_args_with_list_types(self):
# NOTE(flaper87): Regression for bug # NOTE(flaper87): Regression for bug
# https://bugs.launchpad.net/python-glanceclient/+bug/1401032 # https://bugs.launchpad.net/python-glanceclient/+bug/1401032

View File

@@ -504,7 +504,7 @@ class ImageManagerTest(testtools.TestCase):
self.assertEqual(False, image.is_public) self.assertEqual(False, image.is_public)
self.assertEqual(False, image.protected) self.assertEqual(False, image.protected)
self.assertEqual(False, image.deleted) self.assertEqual(False, image.deleted)
self.assertEqual({u'arch': u'x86_64'}, image.properties) self.assertEqual({'arch': 'x86_64'}, image.properties)
def test_get_int(self): def test_get_int(self):
image = self.mgr.get(1) image = self.mgr.get(1)
@@ -515,7 +515,7 @@ class ImageManagerTest(testtools.TestCase):
self.assertEqual(False, image.is_public) self.assertEqual(False, image.is_public)
self.assertEqual(False, image.protected) self.assertEqual(False, image.protected)
self.assertEqual(False, image.deleted) self.assertEqual(False, image.deleted)
self.assertEqual({u'arch': u'x86_64'}, image.properties) self.assertEqual({'arch': 'x86_64'}, image.properties)
def test_get_encoding(self): def test_get_encoding(self):
image = self.mgr.get('3') image = self.mgr.get('3')

View File

@@ -550,10 +550,10 @@ data_fixtures = {
{ {
'id': 'a2b83adc-888e-11e3-8872-78acc0b951d8', 'id': 'a2b83adc-888e-11e3-8872-78acc0b951d8',
'name': 'image-location-tests', 'name': 'image-location-tests',
'locations': [{u'url': u'http://foo.com/', 'locations': [{'url': 'http://foo.com/',
u'metadata': {u'foo': u'foometa'}}, 'metadata': {'foo': 'foometa'}},
{u'url': u'http://bar.com/', {'url': 'http://bar.com/',
u'metadata': {u'bar': u'barmeta'}}], 'metadata': {'bar': 'barmeta'}}],
}, },
), ),
'PATCH': ( 'PATCH': (

View File

@@ -854,7 +854,7 @@ class ShellV2Test(testtools.TestCase):
@mock.patch('sys.stdin', autospec=True) @mock.patch('sys.stdin', autospec=True)
def test_do_image_create_with_unicode(self, mock_stdin): def test_do_image_create_with_unicode(self, mock_stdin):
name = u'\u041f\u0420\u0418\u0412\u0415\u0422\u0418\u041a' name = '\u041f\u0420\u0418\u0412\u0415\u0422\u0418\u041a'
args = self._make_args({'name': name, args = self._make_args({'name': name,
'file': None}) 'file': None})

View File

@@ -55,8 +55,8 @@ source_suffix = '.rst'
master_doc = 'index' master_doc = 'index'
# General information about the project. # General information about the project.
project = u'glanceclient Release Notes' project = 'glanceclient Release Notes'
copyright = u'2016, Glance Developers' copyright = '2016, Glance Developers'
openstackdocs_repo_name = 'openstack/python-glanceclient' openstackdocs_repo_name = 'openstack/python-glanceclient'
openstackdocs_bug_project = 'python-glanceclient' openstackdocs_bug_project = 'python-glanceclient'
@@ -206,8 +206,8 @@ latex_elements = {
# author, documentclass [howto, manual, or own class]). # author, documentclass [howto, manual, or own class]).
latex_documents = [ latex_documents = [
('index', 'glanceclientReleaseNotes.tex', ('index', 'glanceclientReleaseNotes.tex',
u'glanceclient Release Notes Documentation', 'glanceclient Release Notes Documentation',
u'Glance Developers', 'manual'), 'Glance Developers', 'manual'),
] ]
# The name of an image file (relative to this directory) to place at the top of # The name of an image file (relative to this directory) to place at the top of
@@ -237,8 +237,8 @@ latex_documents = [
# (source start file, name, description, authors, manual section). # (source start file, name, description, authors, manual section).
man_pages = [ man_pages = [
('index', 'glanceclientreleasenotes', ('index', 'glanceclientreleasenotes',
u'glanceclient Release Notes Documentation', 'glanceclient Release Notes Documentation',
[u'Glance Developers'], 1) ['Glance Developers'], 1)
] ]
# If true, show URL addresses after external links. # If true, show URL addresses after external links.
@@ -252,8 +252,8 @@ man_pages = [
# dir menu entry, description, category) # dir menu entry, description, category)
texinfo_documents = [ texinfo_documents = [
('index', 'glanceclientReleaseNotes', ('index', 'glanceclientReleaseNotes',
u'glanceclient Release Notes Documentation', 'glanceclient Release Notes Documentation',
u'Glance Developers', 'glanceclientReleaseNotes', 'Glance Developers', 'glanceclientReleaseNotes',
'Python bindings for the OpenStack Image service.', 'Python bindings for the OpenStack Image service.',
'Miscellaneous'), 'Miscellaneous'),
] ]