summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPetri Lehtinen <petri@digip.org>2012-08-15 11:36:14 (GMT)
committerPetri Lehtinen <petri@digip.org>2012-08-15 11:36:14 (GMT)
commitaae61b8cd02479180d326889c717daa413029b4d (patch)
treed18aa2fc04b4cf30134c0d2a733d47cfd8e3c05e
parent3115f0d14b5a8b65be57f21c0866586bd4e06fa2 (diff)
parent3d12c4317c2970d65bf30e941070017a8d1be210 (diff)
downloadcpython-aae61b8cd02479180d326889c717daa413029b4d.zip
cpython-aae61b8cd02479180d326889c717daa413029b4d.tar.gz
cpython-aae61b8cd02479180d326889c717daa413029b4d.tar.bz2
#11062: Fix adding a message from file to Babyl mailbox
-rw-r--r--Lib/mailbox.py2
-rw-r--r--Lib/test/test_mailbox.py18
-rw-r--r--Misc/NEWS2
3 files changed, 9 insertions, 13 deletions
diff --git a/Lib/mailbox.py b/Lib/mailbox.py
index 3ab3396..30877f1 100644
--- a/Lib/mailbox.py
+++ b/Lib/mailbox.py
@@ -1440,9 +1440,9 @@ class Babyl(_singlefileMailbox):
line = line[:-1] + b'\n'
self._file.write(line.replace(b'\n', linesep))
if line == b'\n' or not line:
- self._file.write(b'*** EOOH ***' + linesep)
if first_pass:
first_pass = False
+ self._file.write(b'*** EOOH ***' + linesep)
message.seek(original_pos)
else:
break
diff --git a/Lib/test/test_mailbox.py b/Lib/test/test_mailbox.py
index 52d2cd6..5515357 100644
--- a/Lib/test/test_mailbox.py
+++ b/Lib/test/test_mailbox.py
@@ -152,20 +152,16 @@ class TestMailbox(TestBase):
f.write(_bytes_sample_message)
f.seek(0)
key = self._box.add(f)
- # See issue 11062
- if not isinstance(self._box, mailbox.Babyl):
- self.assertEqual(self._box.get_bytes(key).split(b'\n'),
- _bytes_sample_message.split(b'\n'))
+ self.assertEqual(self._box.get_bytes(key).split(b'\n'),
+ _bytes_sample_message.split(b'\n'))
def test_add_binary_nonascii_file(self):
with tempfile.TemporaryFile('wb+') as f:
f.write(self._non_latin_bin_msg)
f.seek(0)
key = self._box.add(f)
- # See issue 11062
- if not isinstance(self._box, mailbox.Babyl):
- self.assertEqual(self._box.get_bytes(key).split(b'\n'),
- self._non_latin_bin_msg.split(b'\n'))
+ self.assertEqual(self._box.get_bytes(key).split(b'\n'),
+ self._non_latin_bin_msg.split(b'\n'))
def test_add_text_file_warns(self):
with tempfile.TemporaryFile('w+') as f:
@@ -173,10 +169,8 @@ class TestMailbox(TestBase):
f.seek(0)
with self.assertWarns(DeprecationWarning):
key = self._box.add(f)
- # See issue 11062
- if not isinstance(self._box, mailbox.Babyl):
- self.assertEqual(self._box.get_bytes(key).split(b'\n'),
- _bytes_sample_message.split(b'\n'))
+ self.assertEqual(self._box.get_bytes(key).split(b'\n'),
+ _bytes_sample_message.split(b'\n'))
def test_add_StringIO_warns(self):
with self.assertWarns(DeprecationWarning):
diff --git a/Misc/NEWS b/Misc/NEWS
index d242589..2d8b48d 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -13,6 +13,8 @@ Core and Builtins
Library
-------
+- Issue #11062: Fix adding a message from file to Babyl mailbox.
+
- Issue #15646: Prevent equivalent of a fork bomb when using
multiprocessing on Windows without the "if __name__ == '__main__'"
idiom.