diff options
| author | Barry Warsaw | 2014-11-29 17:21:50 -0500 |
|---|---|---|
| committer | Barry Warsaw | 2014-11-29 17:21:50 -0500 |
| commit | 3a94916c286c2be8677c601810c3437262b0fa6f (patch) | |
| tree | 775169a4498f12cbc995401b38efb4f1e8046bf0 | |
| parent | e3357a5c0b4a708d793052efcc5c7d2a5dd3c1ba (diff) | |
| parent | 90d7d6a53f457a529594f6a7fac84ebec0881520 (diff) | |
| download | mailman-3a94916c286c2be8677c601810c3437262b0fa6f.tar.gz mailman-3a94916c286c2be8677c601810c3437262b0fa6f.tar.zst mailman-3a94916c286c2be8677c601810c3437262b0fa6f.zip | |
| -rw-r--r-- | src/mailman/docs/NEWS.rst | 3 | ||||
| -rw-r--r-- | src/mailman/handlers/tests/test_to_digest.py | 62 | ||||
| -rw-r--r-- | src/mailman/handlers/to_digest.py | 2 |
3 files changed, 66 insertions, 1 deletions
diff --git a/src/mailman/docs/NEWS.rst b/src/mailman/docs/NEWS.rst index 5afc6a1e0..ac81cd386 100644 --- a/src/mailman/docs/NEWS.rst +++ b/src/mailman/docs/NEWS.rst @@ -16,6 +16,9 @@ Bugs ---- * Fixed Unicode errors in the digest runner and when sending messages to the site owner as a fallback. Given by Aurélien Bompard. (LP: #1130957). + * Fix Unicode errors when a message being added to the digest has non-ascii + characters in its payload, but no Content-Type header defining a charset. + Given by Aurélien Bompard. (LP: #1170347) Commands -------- diff --git a/src/mailman/handlers/tests/test_to_digest.py b/src/mailman/handlers/tests/test_to_digest.py new file mode 100644 index 000000000..451ebf9a5 --- /dev/null +++ b/src/mailman/handlers/tests/test_to_digest.py @@ -0,0 +1,62 @@ +# Copyright (C) 2014 by the Free Software Foundation, Inc. +# +# This file is part of GNU Mailman. +# +# GNU Mailman is free software: you can redistribute it and/or modify it under +# the terms of the GNU General Public License as published by the Free +# Software Foundation, either version 3 of the License, or (at your option) +# any later version. +# +# GNU Mailman is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for +# more details. +# +# You should have received a copy of the GNU General Public License along with +# GNU Mailman. If not, see <http://www.gnu.org/licenses/>. + +"""Test the to_digest handler.""" + +from __future__ import absolute_import, print_function, unicode_literals + +__metaclass__ = type +__all__ = [ + 'TestToDigest', + ] + + +import os +import unittest + +from mailman.app.lifecycle import create_list +from mailman.handlers.to_digest import ToDigest +from mailman.testing.helpers import specialized_message_from_string as mfs +from mailman.testing.layers import ConfigLayer + + + +class TestToDigest(unittest.TestCase): + """Test the to_digest handler.""" + + layer = ConfigLayer + + def setUp(self): + self._mlist = create_list('test@example.com') + self._msg = mfs("""\ +From: anne@example.com +To: test@example.com +Subject: A disposable message +Message-ID: <ant> + +""") + self._handler = ToDigest() + + def test_unicode_message(self): + # LP: #1170347 - The message has non-ascii characters in its payload, + # but no charset (encoding) is defined e.g. in a Content-Type header. + self._msg.set_payload(b'non-ascii chars \xc3\xa9 \xc3\xa8 \xc3\xa7') + self._msg['X-Test'] = 'dummy' + self._handler.process(self._mlist, self._msg, {}) + # Make sure the digest mbox is not empty. + mailbox_path = os.path.join(self._mlist.data_path, 'digest.mmdf') + self.assertGreater(os.path.getsize(mailbox_path), 0) diff --git a/src/mailman/handlers/to_digest.py b/src/mailman/handlers/to_digest.py index 9eb5818bb..e915bbfa3 100644 --- a/src/mailman/handlers/to_digest.py +++ b/src/mailman/handlers/to_digest.py @@ -55,7 +55,7 @@ class ToDigest: mailbox_path = os.path.join(mlist.data_path, 'digest.mmdf') # Lock the mailbox and append the message. with Mailbox(mailbox_path, create=True) as mbox: - mbox.add(msg) + mbox.add(msg.as_string()) # Calculate the current size of the mailbox file. This will not tell # us exactly how big the resulting MIME and rfc1153 digest will # actually be, but it's the most easily available metric to decide |
