From f273d2abeefa0d77d306bcfab3135195afbc31c3 Mon Sep 17 00:00:00 2001 From: Lisa Junger Date: Wed, 19 Nov 2014 10:44:08 +0100 Subject: added functionality for reply all to service. --- service/test/unit/adapter/mail_test.py | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'service/test/unit/adapter/mail_test.py') diff --git a/service/test/unit/adapter/mail_test.py b/service/test/unit/adapter/mail_test.py index e0879b44..cf821035 100644 --- a/service/test/unit/adapter/mail_test.py +++ b/service/test/unit/adapter/mail_test.py @@ -125,6 +125,15 @@ class TestPixelatedMail(unittest.TestCase): self.assertNotIn('\n', address) self.assertNotIn(',', address) self.assertEquals(4, len(mail.headers[header_label])) + def test_to_reply_template_removes_user_from_to(self): + InputMail.FROM_EMAIL_ADDRESS = 'user@pixelated.org' + fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent']) + mail = PixelatedMail.from_soledad(fdoc, hdoc, bdoc, soledad_querier=self.querier) + hdoc.content['headers']['To'] = ['me@pixelated.org', 'user@pixelated.org'] + + template = mail.to_reply_template() + + self.assertFalse('user@pixelated.org' in template['header']['to'][0]) def test_content_type_is_read_from_headers_for_plain_mail_when_converted_to_raw(self): fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent'], body=u'some umlaut \xc3', extra_headers={'Content-Type': 'text/plain; charset=ISO-8859-1'}) -- cgit v1.2.3 From 9e53c0ddcdd5cd74cda0e9cb6cb05183adbe579c Mon Sep 17 00:00:00 2001 From: Alexandre Pretto Nunes Date: Thu, 27 Nov 2014 17:37:14 -0200 Subject: #135 Have the service respond the email details with who should be on to: and cc: when replying --- service/test/unit/adapter/mail_test.py | 31 +++++++++++++++++-------------- 1 file changed, 17 insertions(+), 14 deletions(-) (limited to 'service/test/unit/adapter/mail_test.py') diff --git a/service/test/unit/adapter/mail_test.py b/service/test/unit/adapter/mail_test.py index cf821035..4cc29287 100644 --- a/service/test/unit/adapter/mail_test.py +++ b/service/test/unit/adapter/mail_test.py @@ -71,7 +71,10 @@ class TestPixelatedMail(unittest.TestCase): def test_as_dict(self): fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent']) hdoc.content['headers']['Subject'] = 'The subject' - hdoc.content['headers']['From'] = 'me@pixelated.org' + hdoc.content['headers']['From'] = 'someone@pixelated.org' + hdoc.content['headers']['To'] = 'me@pixelated.org' + + InputMail.FROM_EMAIL_ADDRESS = 'me@pixelated.org' mail = PixelatedMail.from_soledad(fdoc, hdoc, bdoc, soledad_querier=self.querier) @@ -80,16 +83,25 @@ class TestPixelatedMail(unittest.TestCase): self.assertEquals(_dict, {'body': 'body', 'header': { 'date': dateparser.parse(hdoc.content['date']).isoformat(), - 'from': 'me@pixelated.org', - 'subject': 'The subject' + 'from': 'someone@pixelated.org', + 'subject': 'The subject', + 'to': ['me@pixelated.org'], + 'cc': [], + 'bcc': [] }, 'ident': 'chash', 'mailbox': 'inbox', 'security_casing': {'imprints': [], 'locks': []}, 'status': ['recent'], 'tags': [], - 'attachments': [] - }) + 'attachments': [], + 'replying': { + 'single': 'someone@pixelated.org', + 'all': { + 'to-field': ['someone@pixelated.org'], + 'cc-field': [] + } + }}) def test_alternatives_body(self): parts = {'alternatives': [], 'attachments': []} @@ -125,15 +137,6 @@ class TestPixelatedMail(unittest.TestCase): self.assertNotIn('\n', address) self.assertNotIn(',', address) self.assertEquals(4, len(mail.headers[header_label])) - def test_to_reply_template_removes_user_from_to(self): - InputMail.FROM_EMAIL_ADDRESS = 'user@pixelated.org' - fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent']) - mail = PixelatedMail.from_soledad(fdoc, hdoc, bdoc, soledad_querier=self.querier) - hdoc.content['headers']['To'] = ['me@pixelated.org', 'user@pixelated.org'] - - template = mail.to_reply_template() - - self.assertFalse('user@pixelated.org' in template['header']['to'][0]) def test_content_type_is_read_from_headers_for_plain_mail_when_converted_to_raw(self): fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent'], body=u'some umlaut \xc3', extra_headers={'Content-Type': 'text/plain; charset=ISO-8859-1'}) -- cgit v1.2.3 From 0c53cdd869613f063b4f647b3f8de194a3417b60 Mon Sep 17 00:00:00 2001 From: Alexandre Pretto Nunes Date: Tue, 2 Dec 2014 10:32:33 -0200 Subject: #135 Use reply-to field instead of from when present --- service/test/unit/adapter/mail_test.py | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) (limited to 'service/test/unit/adapter/mail_test.py') diff --git a/service/test/unit/adapter/mail_test.py b/service/test/unit/adapter/mail_test.py index 4cc29287..f436bb6c 100644 --- a/service/test/unit/adapter/mail_test.py +++ b/service/test/unit/adapter/mail_test.py @@ -103,6 +103,25 @@ class TestPixelatedMail(unittest.TestCase): } }}) + def test_use_reply_to_address_for_replying(self): + fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent']) + hdoc.content['headers']['Subject'] = 'The subject' + hdoc.content['headers']['From'] = 'someone@pixelated.org' + hdoc.content['headers']['Reply-To'] = 'reply-to-this-address@pixelated.org' + hdoc.content['headers']['To'] = 'me@pixelated.org, \nalice@pixelated.org' + + InputMail.FROM_EMAIL_ADDRESS = 'me@pixelated.org' + + mail = PixelatedMail.from_soledad(fdoc, hdoc, bdoc, soledad_querier=self.querier) + + _dict = mail.as_dict() + + self.assertEquals(_dict['replying'], {'single': 'reply-to-this-address@pixelated.org', + 'all': { + 'to-field': ['alice@pixelated.org', 'reply-to-this-address@pixelated.org'], + 'cc-field': [] + }}) + def test_alternatives_body(self): parts = {'alternatives': [], 'attachments': []} parts['alternatives'].append({'content': 'blablabla', 'headers': {'Content-Type': 'text/plain'}}) -- cgit v1.2.3 From bd8fd4d18c1f43d2a393cb5cf7aea6abb523fd9a Mon Sep 17 00:00:00 2001 From: Alexandre Pretto Nunes Date: Wed, 3 Dec 2014 15:43:25 -0200 Subject: #135 fix python unit tests --- service/test/unit/adapter/mail_test.py | 30 +++++++++++++++++------------- 1 file changed, 17 insertions(+), 13 deletions(-) (limited to 'service/test/unit/adapter/mail_test.py') diff --git a/service/test/unit/adapter/mail_test.py b/service/test/unit/adapter/mail_test.py index f436bb6c..332fad8a 100644 --- a/service/test/unit/adapter/mail_test.py +++ b/service/test/unit/adapter/mail_test.py @@ -69,10 +69,11 @@ class TestPixelatedMail(unittest.TestCase): self.assertEquals(mail.fdoc.content['flags'], []) def test_as_dict(self): - fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent']) - hdoc.content['headers']['Subject'] = 'The subject' - hdoc.content['headers']['From'] = 'someone@pixelated.org' - hdoc.content['headers']['To'] = 'me@pixelated.org' + headers = {'Subject': 'The subject', + 'From': 'someone@pixelated.org', + 'To': 'me@pixelated.org'} + fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent'], + extra_headers=headers) InputMail.FROM_EMAIL_ADDRESS = 'me@pixelated.org' @@ -104,11 +105,12 @@ class TestPixelatedMail(unittest.TestCase): }}) def test_use_reply_to_address_for_replying(self): - fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent']) - hdoc.content['headers']['Subject'] = 'The subject' - hdoc.content['headers']['From'] = 'someone@pixelated.org' - hdoc.content['headers']['Reply-To'] = 'reply-to-this-address@pixelated.org' - hdoc.content['headers']['To'] = 'me@pixelated.org, \nalice@pixelated.org' + headers = {'Subject': 'The subject', + 'From': 'someone@pixelated.org', + 'Reply-To': 'reply-to-this-address@pixelated.org', + 'To': 'me@pixelated.org, \nalice@pixelated.org'} + fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent'], + extra_headers=headers) InputMail.FROM_EMAIL_ADDRESS = 'me@pixelated.org' @@ -144,10 +146,12 @@ class TestPixelatedMail(unittest.TestCase): self.assertRegexpMatches(mail.body, '([\s\S]*100%){2}') def test_clean_line_breaks_on_address_headers(self): - fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent']) - hdoc.content['headers']['To'] = 'One ,\nTwo , Normal ,\nalone@mail.com' - hdoc.content['headers']['Bcc'] = hdoc.content['headers']['To'] - hdoc.content['headers']['Cc'] = hdoc.content['headers']['To'] + many_recipients = 'One ,\nTwo , Normal ,\nalone@mail.com' + headers = {'Cc': many_recipients, + 'Bcc': many_recipients, + 'To': many_recipients} + fdoc, hdoc, bdoc = test_helper.leap_mail(flags=['\\Recent'], + extra_headers=headers) mail = PixelatedMail.from_soledad(fdoc, hdoc, bdoc, soledad_querier=self.querier) -- cgit v1.2.3