diff --git a/django/core/mail/message.py b/django/core/mail/message.py index f12531af4c..51023768e6 100644 --- a/django/core/mail/message.py +++ b/django/core/mail/message.py @@ -236,7 +236,13 @@ class EmailMessage: self.from_email = from_email or settings.DEFAULT_FROM_EMAIL self.subject = subject self.body = body - self.attachments = attachments or [] + self.attachments = [] + if attachments: + for attachment in attachments: + if isinstance(attachment, MIMEBase): + self.attach(attachment) + else: + self.attach(*attachment) self.extra_headers = headers or {} self.connection = connection diff --git a/docs/releases/1.11.1.txt b/docs/releases/1.11.1.txt index d1e054bb18..a10f3f47ef 100644 --- a/docs/releases/1.11.1.txt +++ b/docs/releases/1.11.1.txt @@ -15,3 +15,6 @@ Bugfixes * Fixed a crash when using a ``__icontains`` lookup on a ``ArrayField`` (:ticket:`28038`). + +* Fixed a crash when using a two-tuple in ``EmailMessage``’s ``attachments`` + argument (:ticket:`28042`). diff --git a/tests/mail/tests.py b/tests/mail/tests.py index 05fe61026f..50922e21d7 100644 --- a/tests/mail/tests.py +++ b/tests/mail/tests.py @@ -374,6 +374,13 @@ class MailTests(HeadersCheckMixin, SimpleTestCase): self.assertEqual(payload[0].get_content_type(), 'multipart/alternative') self.assertEqual(payload[1].get_content_type(), 'application/pdf') + def test_attachments_two_tuple(self): + msg = EmailMessage(attachments=[('filename1', 'content1')]) + filename, content, mimetype = self.get_decoded_attachments(msg)[0] + self.assertEqual(filename, 'filename1') + self.assertEqual(content, b'content1') + self.assertEqual(mimetype, 'application/octet-stream') + def test_attachments_MIMEText(self): txt = MIMEText('content1') msg = EmailMessage(attachments=[txt])