diff options
-rw-r--r-- | service/pixelated/adapter/services/mail_sender.py | 18 | ||||
-rw-r--r-- | service/test/unit/adapter/test_email_recepient_normalizer.py | 42 |
2 files changed, 58 insertions, 2 deletions
diff --git a/service/pixelated/adapter/services/mail_sender.py b/service/pixelated/adapter/services/mail_sender.py index 1c2d7ce1..f4954514 100644 --- a/service/pixelated/adapter/services/mail_sender.py +++ b/service/pixelated/adapter/services/mail_sender.py @@ -14,6 +14,7 @@ # You should have received a copy of the GNU Affero General Public License # along with Pixelated. If not, see <http://www.gnu.org/licenses/>. from StringIO import StringIO +import re from twisted.internet.defer import Deferred from twisted.mail.smtp import SMTPSenderFactory @@ -25,13 +26,26 @@ class MailSender(): def __init__(self, account_email_address, smtp_client=None): self.account_email_address = account_email_address + def recepients_normalizer(self, mail_list): + return set(mail_list) + + def get_email_addresses(self, mail_list): + clean_mail_list = [] + for mail_address in mail_list: + if "<" in mail_address: + match = re.search(r'<(.*)', mail_address) + clean_mail_list.append(match.group(1).strip('>')) + else: + clean_mail_list.append(mail_address) + return self.recepients_normalizer(clean_mail_list) + def sendmail(self, mail): recipients = flatten([mail.to, mail.cc, mail.bcc]) - + normalized_recepients = get_email_addresses(recipients) resultDeferred = Deferred() senderFactory = SMTPSenderFactory( fromEmail=self.account_email_address, - toEmail=recipients, + toEmail=normalized_recipients, file=StringIO(mail.to_smtp_format()), deferred=resultDeferred) diff --git a/service/test/unit/adapter/test_email_recepient_normalizer.py b/service/test/unit/adapter/test_email_recepient_normalizer.py new file mode 100644 index 00000000..79d50273 --- /dev/null +++ b/service/test/unit/adapter/test_email_recepient_normalizer.py @@ -0,0 +1,42 @@ +# +# Copyright (c) 2014 ThoughtWorks, Inc. +# +# Pixelated is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Pixelated is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with Pixelated. If not, see <http://www.gnu.org/licenses/>. +import unittest + +from pixelated.adapter.model.mail import PixelatedMail +from pixelated.adapter.services.mailbox import Mailbox +from pixelated.adapter.services.mail_sender import MailSender +from mockito import * +from test.support import test_helper + + +class PixelatedDuplicateEmailTest(unittest.TestCase): + def setUp(self): + self.mail_sender = MailSender(self, "random@gmail.com") + + def test_remove_duplicate_mail_recepients(self): + mail_list = ['simba@gmail.com', 'simba@gmail.com', 'fabio@gmail.com'] + normalized_recepients = self.mail_sender.recepients_normalizer(mail_list) + self.assertEquals(normalized_recepients, set(['simba@gmail.com', 'fabio@gmail.com'])) + + def test_get_email_addresses(self): + mail_list = ['simbarashe<simba@gmail.com>', 'vic@gmail.com', 'Fabio<fabio@gmail.com>', 'slick@gmail.com'] + selected_recepients = self.mail_sender.get_email_addresses(mail_list) + self.assertEquals(selected_recepients, set(['simba@gmail.com', 'vic@gmail.com', 'fabio@gmail.com', 'slick@gmail.com'])) + + def test_remove_duplicate_emails_with_routing_format(self): + mail_list = ['simbarashe<simba@gmail.com>', 'simba<simba@gmail.com>', 'Fabio<fabio@gmail.com>', 'Fabinho<fabio@gmail.com>'] + selected_recepients = self.mail_sender.get_email_addresses(mail_list) + self.assertEquals(selected_recepients, set(['simba@gmail.com', 'fabio@gmail.com'])) |