Commit 844b0e69 authored by R David Murray's avatar R David Murray

#16811: Fix folding of headers with no value in provisional policies.

parent 36b365cc
...@@ -173,7 +173,7 @@ class EmailPolicy(Policy): ...@@ -173,7 +173,7 @@ class EmailPolicy(Policy):
lines = value.splitlines() lines = value.splitlines()
refold = (self.refold_source == 'all' or refold = (self.refold_source == 'all' or
self.refold_source == 'long' and self.refold_source == 'long' and
(len(lines[0])+len(name)+2 > maxlen or (lines and len(lines[0])+len(name)+2 > maxlen or
any(len(x) > maxlen for x in lines[1:]))) any(len(x) > maxlen for x in lines[1:])))
if refold or refold_binary and _has_surrogates(value): if refold or refold_binary and _has_surrogates(value):
return self.header_factory(name, ''.join(lines)).fold(policy=self) return self.header_factory(name, ''.join(lines)).fold(policy=self)
......
"""Test the parser and generator are inverses.
Note that this is only strictly true if we are parsing RFC valid messages and
producing RFC valid messages.
"""
import io
import unittest
from email import policy, message_from_bytes
from email.generator import BytesGenerator
from test.test_email import TestEmailBase, parameterize
# This is like textwrap.dedent for bytes, except that it uses \r\n for the line
# separators on the rebuilt string.
def dedent(bstr):
lines = bstr.splitlines()
if not lines[0].strip():
raise ValueError("First line must contain text")
stripamt = len(lines[0]) - len(lines[0].lstrip())
return b'\r\n'.join(
[x[stripamt:] if len(x)>=stripamt else b''
for x in lines])
@parameterize
class TestInversion(TestEmailBase, unittest.TestCase):
def msg_as_input(self, msg):
m = message_from_bytes(msg, policy=policy.SMTP)
b = io.BytesIO()
g = BytesGenerator(b)
g.flatten(m)
self.assertEqual(b.getvalue(), msg)
# XXX: spaces are not preserved correctly here yet in the general case.
msg_params = {
'header_with_one_space_body': (dedent(b"""\
From: abc@xyz.com
X-Status:\x20
Subject: test
foo
"""),),
}
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