summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBarry Warsaw2014-11-29 17:21:50 -0500
committerBarry Warsaw2014-11-29 17:21:50 -0500
commit3a94916c286c2be8677c601810c3437262b0fa6f (patch)
tree775169a4498f12cbc995401b38efb4f1e8046bf0
parente3357a5c0b4a708d793052efcc5c7d2a5dd3c1ba (diff)
parent90d7d6a53f457a529594f6a7fac84ebec0881520 (diff)
downloadmailman-3a94916c286c2be8677c601810c3437262b0fa6f.tar.gz
mailman-3a94916c286c2be8677c601810c3437262b0fa6f.tar.zst
mailman-3a94916c286c2be8677c601810c3437262b0fa6f.zip
-rw-r--r--src/mailman/docs/NEWS.rst3
-rw-r--r--src/mailman/handlers/tests/test_to_digest.py62
-rw-r--r--src/mailman/handlers/to_digest.py2
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