From 90621f575dab1d8514a86f7646d96b18f14791e2 Mon Sep 17 00:00:00 2001 From: Timothy Hobbs Date: Fri, 17 Jan 2020 18:11:52 +0100 Subject: [PATCH] Fix ironic ticket creation loop when submitter email == queue email --- helpdesk/models.py | 2 ++ helpdesk/tests/test_ticket_submission.py | 31 ++++++++++++++++++++++++ 2 files changed, 33 insertions(+) diff --git a/helpdesk/models.py b/helpdesk/models.py index 12d316c5..41bf756b 100644 --- a/helpdesk/models.py +++ b/helpdesk/models.py @@ -613,6 +613,8 @@ class Ticket(models.Model): if dont_send_to is not None: recipients.update(dont_send_to) + recipients.add(self.queue.email_address) + def should_receive(email): return email and email not in recipients diff --git a/helpdesk/tests/test_ticket_submission.py b/helpdesk/tests/test_ticket_submission.py index 31fb0b68..41efcca3 100644 --- a/helpdesk/tests/test_ticket_submission.py +++ b/helpdesk/tests/test_ticket_submission.py @@ -140,6 +140,37 @@ class TicketBasicsTestCase(TestCase): # Ensure only two e-mails were sent - submitter & updated. self.assertEqual(email_count + 2, len(mail.outbox)) + def test_create_ticket_public_no_loopback(self): + """ + Don't send emails to the queue's own inbox. It'll create a loop. + """ + email_count = len(mail.outbox) + + self.queue_public.email_address = "queue@example.com" + self.queue_public.save() + + post_data = { + 'title': 'Test ticket title', + 'queue': self.queue_public.id, + 'submitter_email': 'queue@example.com', + 'body': 'Test ticket body', + 'priority': 3, + } + + response = self.client.post(reverse('helpdesk:home'), post_data, follow=True) + last_redirect = response.redirect_chain[-1] + last_redirect_url = last_redirect[0] + # last_redirect_status = last_redirect[1] + + # Ensure we landed on the "View" page. + # Django 1.9 compatible way of testing this + # https://docs.djangoproject.com/en/1.9/releases/1.9/#http-redirects-no-longer-forced-to-absolute-uris + urlparts = urlparse(last_redirect_url) + self.assertEqual(urlparts.path, reverse('helpdesk:public_view')) + + # Ensure submitter, new-queue + update-queue were all emailed. + self.assertEqual(email_count + 2, len(mail.outbox)) + class EmailInteractionsTestCase(TestCase): fixtures = ['emailtemplate.json']