Commit 7da8f06d authored by R. David Murray's avatar R. David Murray

#4768: store base64 encoded email body parts as text, not binary.

Patch and tests by Forest Bond.
parent deda8cb8
......@@ -29,7 +29,7 @@ def encode_base64(msg):
Also, add an appropriate Content-Transfer-Encoding header.
"""
orig = msg.get_payload()
encdata = _bencode(orig)
encdata = str(_bencode(orig), 'ascii')
msg.set_payload(encdata)
msg['Content-Transfer-Encoding'] = 'base64'
......
......@@ -970,7 +970,8 @@ class TestMIMEAudio(unittest.TestCase):
def test_encoding(self):
payload = self._au.get_payload()
self.assertEqual(base64.decodebytes(payload), self._audiodata)
self.assertEqual(base64.decodebytes(bytes(payload, 'ascii')),
self._audiodata)
def test_checkSetMinor(self):
au = MIMEAudio(self._audiodata, 'fish')
......@@ -1010,7 +1011,8 @@ class TestMIMEImage(unittest.TestCase):
def test_encoding(self):
payload = self._im.get_payload()
self.assertEqual(base64.decodebytes(payload), self._imgdata)
self.assertEqual(base64.decodebytes(bytes(payload, 'ascii')),
self._imgdata)
def test_checkSetMinor(self):
im = MIMEImage(self._imgdata, 'fish')
......@@ -1050,7 +1052,7 @@ class TestMIMEApplication(unittest.TestCase):
eq = self.assertEqual
bytes = b'\xfa\xfb\xfc\xfd\xfe\xff'
msg = MIMEApplication(bytes)
eq(msg.get_payload(), b'+vv8/f7/')
eq(msg.get_payload(), '+vv8/f7/')
eq(msg.get_payload(decode=True), bytes)
......
......@@ -83,6 +83,7 @@ Finn Bock
Paul Boddie
Matthew Boedicker
David Bolen
Forest Bond
Gawain Bolton
Gregory Bond
Jurjen Bos
......
......@@ -398,6 +398,9 @@ C-API
Library
-------
- Issue #4768: base64 encoded email body parts were incorrectly stored as
binary strings. They are now correctly converted to strings.
- Issue #8833: tarfile created hard link entries with a size field != 0 by
mistake.
......
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