]> granicus.if.org Git - python/commitdiff
[email] bpo-29478: Fix passing max_line_length=None from Compat32 policy (GH-595)
authormircea-cosbuc <mircea-cosbuc@users.noreply.github.com>
Mon, 12 Jun 2017 06:43:41 +0000 (08:43 +0200)
committerMariatta <Mariatta@users.noreply.github.com>
Mon, 12 Jun 2017 06:43:41 +0000 (23:43 -0700)
If max_line_length=None is specified while using the Compat32 policy,
it is no longer ignored.

Lib/email/_policybase.py
Lib/test/test_email/test_generator.py
Misc/ACKS
Misc/NEWS

index df4649676aed72418864b87494a215fde74cd4ed..c9cbadd2a80c48e7ce1c9247a22fd3024f365249 100644 (file)
@@ -361,8 +361,12 @@ class Compat32(Policy):
             # Assume it is a Header-like object.
             h = value
         if h is not None:
-            parts.append(h.encode(linesep=self.linesep,
-                                  maxlinelen=self.max_line_length))
+            # The Header class interprets a value of None for maxlinelen as the
+            # default value of 78, as recommended by RFC 2822.
+            maxlinelen = 0
+            if self.max_line_length is not None:
+                maxlinelen = self.max_line_length
+            parts.append(h.encode(linesep=self.linesep, maxlinelen=maxlinelen))
         parts.append(self.linesep)
         return ''.join(parts)
 
index 7c8877fdcb090ee36844a173f2c8d971cbe7ffae..c4f182903afefea848983045a42ef6dec3baecc4 100644 (file)
@@ -162,6 +162,13 @@ class TestGeneratorBase:
                 g.flatten(msg)
                 self.assertEqual(s.getvalue(), self.typ(expected))
 
+    def test_compat32_max_line_length_does_not_fold_when_none(self):
+        msg = self.msgmaker(self.typ(self.refold_long_expected[0]))
+        s = self.ioclass()
+        g = self.genclass(s, policy=policy.compat32.clone(max_line_length=None))
+        g.flatten(msg)
+        self.assertEqual(s.getvalue(), self.typ(self.refold_long_expected[0]))
+
 
 class TestGenerator(TestGeneratorBase, TestEmailBase):
 
index 74ac15b89ece6ba22a9db3c60eb8f4d66b573887..1ae9b6fe5d0a2e3f8f2d91c44210c43c1f95121e 100644 (file)
--- a/Misc/ACKS
+++ b/Misc/ACKS
@@ -310,6 +310,7 @@ Garrett Cooper
 Greg Copeland
 Ian Cordasco
 Aldo Cortesi
+Mircea Cosbuc
 David Costanzo
 Scott Cotton
 Greg Couch
index 98d8ef96b3e6c2858708c55312b1ed14380b4033..88f1631c31576180301c5af3d947d3577e8b2cc5 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -142,6 +142,9 @@ Core and Builtins
 
 - bpo-29546: Improve from-import error message with location
 
+- bpo-29478: If max_line_length=None is specified while using the Compat32 policy,
+  it is no longer ignored.  Patch by Mircea Cosbuc.
+
 - Issue #29319: Prevent RunMainFromImporter overwriting sys.path[0].
 
 - Issue #29337: Fixed possible BytesWarning when compare the code objects.