mirror of
https://github.com/python/cpython.git
synced 2025-07-23 11:15:24 +00:00
bpo-35805: Add parser for Message-ID email header. (GH-13397)
* bpo-35805: Add parser for Message-ID header. This parser is based on the definition of Identification Fields from RFC 5322 Sec 3.6.4. This should also prevent folding of Message-ID header using RFC 2047 encoded words and hence fix bpo-35805. * Prevent folding of non-ascii message-id headers. * Add fold method to MsgID token to prevent folding.
This commit is contained in:
parent
bc6469f79c
commit
46d88a1131
6 changed files with 257 additions and 28 deletions
|
@ -1648,6 +1648,34 @@ class TestFolding(TestHeaderBase):
|
|||
'xxxxxxxxxxxxxxxxxxxx=3D=3D-xxx-xx-xx?=\n'
|
||||
' =?utf-8?q?=3E?=\n')
|
||||
|
||||
def test_message_id_header_is_not_folded(self):
|
||||
h = self.make_header(
|
||||
'Message-ID',
|
||||
'<somemessageidlongerthan@maxlinelength.com>')
|
||||
self.assertEqual(
|
||||
h.fold(policy=policy.default.clone(max_line_length=20)),
|
||||
'Message-ID: <somemessageidlongerthan@maxlinelength.com>\n')
|
||||
|
||||
# Test message-id isn't folded when id-right is no-fold-literal.
|
||||
h = self.make_header(
|
||||
'Message-ID',
|
||||
'<somemessageidlongerthan@[127.0.0.0.0.0.0.0.0.1]>')
|
||||
self.assertEqual(
|
||||
h.fold(policy=policy.default.clone(max_line_length=20)),
|
||||
'Message-ID: <somemessageidlongerthan@[127.0.0.0.0.0.0.0.0.1]>\n')
|
||||
|
||||
# Test message-id isn't folded when id-right is non-ascii characters.
|
||||
h = self.make_header('Message-ID', '<ईमेल@wők.com>')
|
||||
self.assertEqual(
|
||||
h.fold(policy=policy.default.clone(max_line_length=30)),
|
||||
'Message-ID: <ईमेल@wők.com>\n')
|
||||
|
||||
# Test message-id is folded without breaking the msg-id token into
|
||||
# encoded words, *even* if they don't fit into max_line_length.
|
||||
h = self.make_header('Message-ID', '<ईमेलfromMessage@wők.com>')
|
||||
self.assertEqual(
|
||||
h.fold(policy=policy.default.clone(max_line_length=20)),
|
||||
'Message-ID:\n <ईमेलfromMessage@wők.com>\n')
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue