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

Patch and tests by Forest Bond.
This commit is contained in:
R. David Murray 2010-06-04 16:11:08 +00:00
parent deda8cb835
commit 7da8f06df0
4 changed files with 10 additions and 4 deletions

View File

@ -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'

View File

@ -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)

View File

@ -83,6 +83,7 @@ Finn Bock
Paul Boddie
Matthew Boedicker
David Bolen
Forest Bond
Gawain Bolton
Gregory Bond
Jurjen Bos

View File

@ -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.