summaryrefslogtreecommitdiff
path: root/tests/mail/test_sendtestemail.py
diff options
context:
space:
mode:
authorRolo <rolo@wildfish.com>2015-06-16 13:46:56 +0100
committerTim Graham <timograham@gmail.com>2015-06-22 07:21:26 -0400
commite7b4bd48c7b81718cfae6f30f1868cf45311ca86 (patch)
treee7d7b83eac078742e5b52c5e0827ec974413200e /tests/mail/test_sendtestemail.py
parent1c90a3dccadc7d2da3704ff17ac9ff1a67743934 (diff)
downloaddjango-e7b4bd48c7b81718cfae6f30f1868cf45311ca86.tar.gz
Fixed #24970 -- Added --managers and --admins options to the sendtestemail management command.
Diffstat (limited to 'tests/mail/test_sendtestemail.py')
-rw-r--r--tests/mail/test_sendtestemail.py67
1 files changed, 59 insertions, 8 deletions
diff --git a/tests/mail/test_sendtestemail.py b/tests/mail/test_sendtestemail.py
index ccf04f9d77..b1494bf3df 100644
--- a/tests/mail/test_sendtestemail.py
+++ b/tests/mail/test_sendtestemail.py
@@ -2,32 +2,83 @@ from __future__ import unicode_literals
from django.core import mail
from django.core.management import call_command
-from django.test import SimpleTestCase
+from django.test import SimpleTestCase, override_settings
+@override_settings(
+ ADMINS=(('Admin', 'admin@example.com'), ('Admin and Manager', 'admin_and_manager@example.com')),
+ MANAGERS=(('Manager', 'manager@example.com'), ('Admin and Manager', 'admin_and_manager@example.com')),
+)
class SendTestEmailManagementCommand(SimpleTestCase):
"""
Test the sending of a test email using the `sendtestemail` command.
"""
- def test_send_test_email(self):
+ def test_single_receiver(self):
"""
The mail is sent with the correct subject and recipient.
"""
- recipient = "joe@example.com"
- call_command("sendtestemail", recipient)
+ recipient = 'joe@example.com'
+ call_command('sendtestemail', recipient)
self.assertEqual(len(mail.outbox), 1)
mail_message = mail.outbox[0]
self.assertEqual(mail_message.subject[0:15], 'Test email from')
self.assertEqual(mail_message.recipients(), [recipient])
- def test_send_test_email_with_multiple_addresses(self):
+ def test_multiple_receivers(self):
"""
The mail may be sent with multiple recipients.
"""
- recipients = ["joe@example.com", "jane@example.com"]
- call_command("sendtestemail", recipients[0], recipients[1])
+ recipients = ['joe@example.com', 'jane@example.com']
+ call_command('sendtestemail', recipients[0], recipients[1])
self.assertEqual(len(mail.outbox), 1)
mail_message = mail.outbox[0]
self.assertEqual(mail_message.subject[0:15], 'Test email from')
- self.assertEqual(mail_message.recipients(), recipients)
+ self.assertEqual(sorted(mail_message.recipients()), [
+ 'jane@example.com',
+ 'joe@example.com',
+ ])
+
+ def test_manager_receivers(self):
+ """
+ The mail should be sent to the email addresses specified in
+ settings.MANAGERS.
+ """
+ call_command('sendtestemail', '--managers')
+ self.assertEqual(len(mail.outbox), 1)
+ mail_message = mail.outbox[0]
+ self.assertEqual(sorted(mail_message.recipients()), [
+ 'admin_and_manager@example.com',
+ 'manager@example.com',
+ ])
+
+ def test_admin_receivers(self):
+ """
+ The mail should be sent to the email addresses specified in
+ settings.ADMIN.
+ """
+ call_command('sendtestemail', '--admins')
+ self.assertEqual(len(mail.outbox), 1)
+ mail_message = mail.outbox[0]
+ self.assertEqual(sorted(mail_message.recipients()), [
+ 'admin@example.com',
+ 'admin_and_manager@example.com',
+ ])
+
+ def test_manager_and_admin_receivers(self):
+ """
+ The mail should be sent to the email addresses specified in both
+ settings.MANAGERS and settings.ADMINS.
+ """
+ call_command('sendtestemail', '--managers', '--admins')
+ self.assertEqual(len(mail.outbox), 2)
+ manager_mail = mail.outbox[0]
+ self.assertEqual(sorted(manager_mail.recipients()), [
+ 'admin_and_manager@example.com',
+ 'manager@example.com',
+ ])
+ admin_mail = mail.outbox[1]
+ self.assertEqual(sorted(admin_mail.recipients()), [
+ 'admin@example.com',
+ 'admin_and_manager@example.com',
+ ])