From 478e791c39c3bcda667021cda2a25a1abb867d86 Mon Sep 17 00:00:00 2001 From: imran Date: Sun, 4 Sep 2016 04:31:03 +0600 Subject: [PATCH] Fix unicode S3 key listing in Python 2 --- moto/s3/utils.py | 3 +++ tests/test_s3/test_s3.py | 7 ++++--- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/moto/s3/utils.py b/moto/s3/utils.py index e86578ec5..8ea18c207 100644 --- a/moto/s3/utils.py +++ b/moto/s3/utils.py @@ -46,6 +46,9 @@ def metadata_from_headers(headers): def clean_key_name(key_name): + if six.PY2: + return unquote(key_name.encode('utf-8')).decode('utf-8') + return unquote(key_name) diff --git a/tests/test_s3/test_s3.py b/tests/test_s3/test_s3.py index 95a755ab1..7c933c550 100644 --- a/tests/test_s3/test_s3.py +++ b/tests/test_s3/test_s3.py @@ -846,9 +846,10 @@ def test_unicode_key(): key = Key(bucket) key.key = u'こんにちは.jpg' key.set_contents_from_string('Hello world!') - list(bucket.list()) - key = bucket.get_key(key.key) - assert key.get_contents_as_string().decode("utf-8") == 'Hello world!' + assert [listed_key.key for listed_key in bucket.list()] == [key.key] + fetched_key = bucket.get_key(key.key) + assert fetched_key.key == key.key + assert fetched_key.get_contents_as_string().decode("utf-8") == 'Hello world!' @mock_s3