2017-10-25 01:58:05 +02:00
|
|
|
import os
|
2020-05-26 07:16:25 +02:00
|
|
|
from unittest import mock
|
2020-06-11 00:54:34 +02:00
|
|
|
|
2017-10-25 01:58:05 +02:00
|
|
|
from django.conf import settings
|
|
|
|
|
|
|
|
from zerver.lib.test_classes import ZulipTestCase
|
|
|
|
from zproject.email_backends import get_forward_address
|
|
|
|
|
2020-06-11 00:54:34 +02:00
|
|
|
|
2017-10-25 01:58:05 +02:00
|
|
|
class EmailLogTest(ZulipTestCase):
|
2018-08-06 11:40:31 +02:00
|
|
|
def test_generate_and_clear_email_log(self) -> None:
|
|
|
|
with self.settings(EMAIL_BACKEND='zproject.email_backends.EmailLogBackEnd'), \
|
2021-01-28 19:28:34 +01:00
|
|
|
mock.patch('zproject.email_backends.EmailBackend.send_messages'), \
|
2020-10-29 20:21:18 +01:00
|
|
|
self.assertLogs(level="INFO") as m, \
|
2018-08-06 11:40:31 +02:00
|
|
|
self.settings(DEVELOPMENT_LOG_EMAILS=True):
|
|
|
|
result = self.client_get('/emails/generate/')
|
|
|
|
self.assertEqual(result.status_code, 302)
|
|
|
|
self.assertIn('emails', result['Location'])
|
2017-10-25 01:58:05 +02:00
|
|
|
|
2018-08-06 11:40:31 +02:00
|
|
|
result = self.client_get("/emails/")
|
|
|
|
self.assert_in_success_response(["All the emails sent in the Zulip"], result)
|
2017-10-25 01:58:05 +02:00
|
|
|
|
2018-08-06 11:40:31 +02:00
|
|
|
result = self.client_get('/emails/clear/')
|
|
|
|
self.assertEqual(result.status_code, 302)
|
|
|
|
result = self.client_get(result['Location'])
|
|
|
|
self.assertIn('manually generate most of the emails by clicking', str(result.content))
|
2020-10-29 20:21:18 +01:00
|
|
|
output_log = "INFO:root:Emails sent in development are available at http://testserver/emails"
|
|
|
|
self.assertEqual(m.output, [output_log for i in range(15)])
|
2017-10-25 01:58:05 +02:00
|
|
|
|
2017-11-05 10:51:25 +01:00
|
|
|
def test_forward_address_details(self) -> None:
|
2017-10-25 01:58:05 +02:00
|
|
|
forward_address = "forward-to@example.com"
|
|
|
|
result = self.client_post("/emails/", {"forward_address": forward_address})
|
|
|
|
self.assert_json_success(result)
|
|
|
|
|
|
|
|
self.assertEqual(get_forward_address(), forward_address)
|
|
|
|
|
2020-10-28 10:32:49 +01:00
|
|
|
with self.settings(EMAIL_BACKEND='zproject.email_backends.EmailLogBackEnd'):
|
2021-01-28 19:28:34 +01:00
|
|
|
with mock.patch('zproject.email_backends.EmailBackend.send_messages'):
|
2017-10-25 01:58:05 +02:00
|
|
|
result = self.client_get('/emails/generate/')
|
|
|
|
self.assertEqual(result.status_code, 302)
|
|
|
|
self.assertIn('emails', result['Location'])
|
|
|
|
result = self.client_get(result['Location'])
|
|
|
|
self.assert_in_success_response([forward_address], result)
|
|
|
|
os.remove(settings.FORWARD_ADDRESS_CONFIG_FILE)
|