Commit 6cb1d67e authored by R David Murray's avatar R David Murray

Merge: #16564: Fix regression in use of encoders.encode_noop with binary data.

parents 7d01a1eb ceaa8b1d
...@@ -76,3 +76,9 @@ def encode_7or8bit(msg): ...@@ -76,3 +76,9 @@ def encode_7or8bit(msg):
def encode_noop(msg): def encode_noop(msg):
"""Do nothing.""" """Do nothing."""
# Well, not quite *nothing*: in Python3 we have to turn bytes into a string
# in our internal surrogateescaped form in order to keep the model
# consistent.
orig = msg.get_payload()
if not isinstance(orig, str):
msg.set_payload(orig.decode('ascii', 'surrogateescape'))
...@@ -406,6 +406,9 @@ class BytesGenerator(Generator): ...@@ -406,6 +406,9 @@ class BytesGenerator(Generator):
else: else:
super(BytesGenerator,self)._handle_text(msg) super(BytesGenerator,self)._handle_text(msg)
# Default body handler
_writeBody = _handle_text
@classmethod @classmethod
def _compile_re(cls, s, flags): def _compile_re(cls, s, flags):
return re.compile(s.encode('ascii'), flags) return re.compile(s.encode('ascii'), flags)
......
...@@ -1440,6 +1440,22 @@ class TestMIMEApplication(unittest.TestCase): ...@@ -1440,6 +1440,22 @@ class TestMIMEApplication(unittest.TestCase):
eq(msg.get_payload().strip(), '+vv8/f7/') eq(msg.get_payload().strip(), '+vv8/f7/')
eq(msg.get_payload(decode=True), bytesdata) eq(msg.get_payload(decode=True), bytesdata)
def test_body_with_encode_noop(self):
# Issue 16564: This does not produce an RFC valid message, since to be
# valid it should have a CTE of binary. But the below works in
# Python2, and is documented as working this way.
bytesdata = b'\xfa\xfb\xfc\xfd\xfe\xff'
msg = MIMEApplication(bytesdata, _encoder=encoders.encode_noop)
# Treated as a string, this will be invalid code points.
self.assertEqual(msg.get_payload(), '\uFFFD' * len(bytesdata))
self.assertEqual(msg.get_payload(decode=True), bytesdata)
s = BytesIO()
g = BytesGenerator(s)
g.flatten(msg)
wireform = s.getvalue()
msg2 = email.message_from_bytes(wireform)
self.assertEqual(msg.get_payload(), '\uFFFD' * len(bytesdata))
self.assertEqual(msg2.get_payload(decode=True), bytesdata)
# Test the basic MIMEText class # Test the basic MIMEText class
......
...@@ -169,6 +169,9 @@ Core and Builtins ...@@ -169,6 +169,9 @@ Core and Builtins
Library Library
------- -------
- Issue #16564: Fixed regression relative to Python2 in the operation of
email.encoders.encode_noop when used with binary data.
- Issue #10355: In SpooledTemporaryFile class mode, name, encoding and - Issue #10355: In SpooledTemporaryFile class mode, name, encoding and
newlines properties now work for unrolled files. Obsoleted and never newlines properties now work for unrolled files. Obsoleted and never
working on Python 3 xreadline method now removed. working on Python 3 xreadline method now removed.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment