diff options
author | Barry Warsaw <barry@python.org> | 2015-01-26 16:18:57 -0500 |
---|---|---|
committer | Barry Warsaw <barry@python.org> | 2015-01-26 16:18:57 -0500 |
commit | 2329d28a316e0ea6874b9457a1c04b37895adfd2 (patch) | |
tree | 7eb0fb9a5f8f3f10ba4342a042e4144344bbe549 /cloudinit | |
parent | f5d6d0e6433f12d05676bea03f78d57966c35b0a (diff) | |
download | vyos-cloud-init-2329d28a316e0ea6874b9457a1c04b37895adfd2.tar.gz vyos-cloud-init-2329d28a316e0ea6874b9457a1c04b37895adfd2.zip |
Python 3 tests pass, except for skips.
Diffstat (limited to 'cloudinit')
-rw-r--r-- | cloudinit/user_data.py | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/cloudinit/user_data.py b/cloudinit/user_data.py index ff21259c..3f860f3b 100644 --- a/cloudinit/user_data.py +++ b/cloudinit/user_data.py @@ -108,6 +108,7 @@ class UserDataProcessor(object): ctype = None ctype_orig = part.get_content_type() + ctype_main = part.get_content_maintype() payload = part.get_payload(decode=True) # In Python 3, decoding the payload will ironically hand us a # bytes object. 'decode' means to decode according to @@ -115,7 +116,7 @@ class UserDataProcessor(object): # Content-Type. So, if we end up with bytes, first try to decode # to str via CT charset, and failing that, try utf-8 using # surrogate escapes. - if six.PY3 and isinstance(payload, bytes): + if six.PY3 and ctype_main == 'text' and isinstance(payload, bytes): charset = part.get_charset() or 'utf-8' payload = payload.decode(charset, errors='surrogateescape') was_compressed = False @@ -131,6 +132,7 @@ class UserDataProcessor(object): ctype_orig = None was_compressed = True except util.DecompressionError as e: + import pdb; pdb.set_trace() LOG.warn("Failed decompressing payload from %s of length" " %s due to: %s", ctype_orig, len(payload), e) continue |