From 811aa0b5850344f65e0b16831f537143a5c461ad Mon Sep 17 00:00:00 2001 From: Jefferson Stachelski Date: Wed, 25 Nov 2015 18:04:03 -0200 Subject: Issue #515 - Removed the Bcc when sending email --- service/pixelated/adapter/services/mail_sender.py | 6 ++++ .../test/unit/adapter/services/test_mail_sender.py | 36 ++++++++++++++++++---- 2 files changed, 36 insertions(+), 6 deletions(-) diff --git a/service/pixelated/adapter/services/mail_sender.py b/service/pixelated/adapter/services/mail_sender.py index bcbf331c..acd9f034 100644 --- a/service/pixelated/adapter/services/mail_sender.py +++ b/service/pixelated/adapter/services/mail_sender.py @@ -60,9 +60,15 @@ class MailSender(object): def _send_mail_to_all_recipients(self, mail, recipients): outgoing_mail = self._create_outgoing_mail() + bccs = mail.bcc deferreds = [] for recipient in recipients: + if recipient in bccs: + mail.headers['Bcc'] = [recipient] + else: + mail.headers['Bcc'] = [] + smtp_recipient = self._create_twisted_smtp_recipient(recipient) deferreds.append(outgoing_mail.send_message(mail.to_smtp_format(), smtp_recipient)) diff --git a/service/test/unit/adapter/services/test_mail_sender.py b/service/test/unit/adapter/services/test_mail_sender.py index f7103b60..562f919d 100644 --- a/service/test/unit/adapter/services/test_mail_sender.py +++ b/service/test/unit/adapter/services/test_mail_sender.py @@ -39,6 +39,19 @@ class TwistedSmtpUserCapture(Matcher): and self._username == arg.dest.addrstr +class MailToSmtpFormatCapture(Matcher): + + def __init__(self, recipient, bccs): + self._recipient = recipient + self._bccs = bccs + + def matches(self, mail): + if self._recipient in self._bccs: + return 'Bcc: %s\n' % self._recipient in mail + else: + return "Bcc: " not in mail + + class MailSenderTest(unittest.TestCase): def setUp(self): @@ -47,32 +60,43 @@ class MailSenderTest(unittest.TestCase): self._remote_smtp_host = 'some.host.test' self._remote_smtp_port = 1234 self._smtp_config = LeapSMTPConfig('someone@somedomain.tld', self._cert_path, self._remote_smtp_host, self._remote_smtp_port) + self.sender = MailSender(self._smtp_config, self._keymanager_mock) def tearDown(self): unstub() @defer.inlineCallbacks def test_iterates_over_recipients(self): - sender = MailSender(self._smtp_config, self._keymanager_mock) input_mail = InputMail.from_dict(mail_dict()) - when(OutgoingMail).send_message(any(), any()).thenAnswer(lambda: defer.succeed(None)) + when(OutgoingMail).send_message(any(), any()).thenReturn(defer.succeed(None)) - yield sender.sendmail(input_mail) + yield self.sender.sendmail(input_mail) for recipient in flatten([input_mail.to, input_mail.cc, input_mail.bcc]): verify(OutgoingMail).send_message(any(), TwistedSmtpUserCapture(recipient)) @defer.inlineCallbacks def test_problem_with_email_raises_exception(self): - sender = MailSender(self._smtp_config, self._keymanager_mock) input_mail = InputMail.from_dict(mail_dict()) - when(OutgoingMail).send_message(any(), any()).thenAnswer(lambda: defer.fail(Exception('pretend something went wrong'))) + when(OutgoingMail).send_message(any(), any()).thenReturn(defer.fail(Exception('pretend something went wrong'))) try: - yield sender.sendmail(input_mail) + yield self.sender.sendmail(input_mail) self.fail('Exception expected!') except MailSenderException, e: for recipient in flatten([input_mail.to, input_mail.cc, input_mail.bcc]): self.assertTrue(recipient in e.email_error_map) + + @defer.inlineCallbacks + def test_iterates_over_recipients_and_send_whitout_bcc_field(self): + input_mail = InputMail.from_dict(mail_dict()) + bccs = input_mail.bcc + + when(OutgoingMail).send_message(any(), any()).thenReturn(defer.succeed(None)) + + yield self.sender.sendmail(input_mail) + + for recipient in flatten([input_mail.to, input_mail.cc, input_mail.bcc]): + verify(OutgoingMail).send_message(MailToSmtpFormatCapture(recipient, bccs), TwistedSmtpUserCapture(recipient)) -- cgit v1.2.3