diff options
-rw-r--r-- | service/integration/__init__.py | 19 | ||||
-rw-r--r-- | service/integration/drafts_test.py | 12 | ||||
-rw-r--r-- | service/integration/tags_test.py | 43 | ||||
-rw-r--r-- | service/pixelated/adapter/pixelated_mailboxes.py | 3 |
4 files changed, 67 insertions, 10 deletions
diff --git a/service/integration/__init__.py b/service/integration/__init__.py index 22643b95..c4e1d0b4 100644 --- a/service/integration/__init__.py +++ b/service/integration/__init__.py @@ -24,7 +24,7 @@ from pixelated.adapter.mail_service import MailService from pixelated.adapter.tag_index import TagIndex from pixelated.adapter.tag_service import TagService import pixelated.user_agent -from pixelated.adapter.pixelated_mail import PixelatedMail +from pixelated.adapter.pixelated_mail import PixelatedMail, InputMail from pixelated.adapter.pixelated_mailboxes import PixelatedMailBoxes from pixelated.adapter.soledad_querier import SoledadQuerier @@ -71,7 +71,7 @@ def initialize_soledad(tempdir): return _soledad -class JSONMailBuilder: +class MailBuilder: def __init__(self): self.mail = { 'header': { @@ -95,9 +95,13 @@ class JSONMailBuilder: self.mail['ident'] = ident return self - def build(self): + def build_json(self): return json.dumps(self.mail) + def build_input_mail(self): + return InputMail.from_dict(self.mail) + + class SoledadTestBase: @@ -135,6 +139,9 @@ class SoledadTestBase: response = json.loads(self.app.put('/mails', data=data, content_type="application/json").data) return response['ident'] + def post_tags(self, mail_ident, tags_json): + return json.loads(self.app.post('/mail/' + mail_ident + '/tags', data=tags_json, content_type="application/json").data) + class ResponseMail: @@ -151,4 +158,8 @@ class ResponseMail: @property def ident(self): - return self.mail_dict['ident']
\ No newline at end of file + return self.mail_dict['ident'] + + @property + def tags(self): + return self.mail_dict['tags']
\ No newline at end of file diff --git a/service/integration/drafts_test.py b/service/integration/drafts_test.py index a3ecbb2a..749b1ad3 100644 --- a/service/integration/drafts_test.py +++ b/service/integration/drafts_test.py @@ -14,7 +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/>. import unittest -from integration import JSONMailBuilder, SoledadTestBase +from integration import MailBuilder, SoledadTestBase class DraftsTest(unittest.TestCase, SoledadTestBase): @@ -26,7 +26,7 @@ class DraftsTest(unittest.TestCase, SoledadTestBase): self.teardown_soledad() def test_post_creates_a_draft_when_data_has_no_ident(self): - mail = JSONMailBuilder().with_subject('A new draft').build() + mail = MailBuilder().with_subject('A new draft').build_json() self.post_mail(mail) mails = self.get_mails_by_tag('drafts') @@ -34,11 +34,11 @@ class DraftsTest(unittest.TestCase, SoledadTestBase): self.assertEquals('A new draft', mails[0].subject) def test_post_sends_mail_and_deletes_previous_draft_when_data_has_ident(self): - first_draft = JSONMailBuilder().with_subject('First draft').build() + first_draft = MailBuilder().with_subject('First draft').build_json() first_draft_response = self.post_mail(first_draft) first_draft_ident = first_draft_response.ident - second_draft = JSONMailBuilder().with_subject('Second draft').with_ident(first_draft_ident).build() + second_draft = MailBuilder().with_subject('Second draft').with_ident(first_draft_ident).build_json() self.post_mail(second_draft) sent_mails = self.get_mails_by_tag('sent') @@ -49,11 +49,11 @@ class DraftsTest(unittest.TestCase, SoledadTestBase): self.assertEquals(0, len(drafts)) def test_update_draft(self): - draft = JSONMailBuilder().with_subject('First draft').build() + draft = MailBuilder().with_subject('First draft').build_json() create_draft_response = self.post_mail(draft) draft_ident = create_draft_response.ident - updated_draft = JSONMailBuilder().with_subject('First draft edited').with_ident(draft_ident).build() + updated_draft = MailBuilder().with_subject('First draft edited').with_ident(draft_ident).build_json() self.put_mail(updated_draft) drafts = self.get_mails_by_tag('drafts') diff --git a/service/integration/tags_test.py b/service/integration/tags_test.py new file mode 100644 index 00000000..8971fac7 --- /dev/null +++ b/service/integration/tags_test.py @@ -0,0 +1,43 @@ +# +# 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 json +import unittest +from integration import MailBuilder, SoledadTestBase + + +class TagsTest(unittest.TestCase, SoledadTestBase): + + def setUp(self): + self.setup_soledad() + + def tearDown(self): + self.teardown_soledad() + + def _tags_json(self, tags): + return json.dumps({'newtags': tags}) + + def test_add_tag_to_an_inbox_mail_and_query(self): + mail = MailBuilder().with_subject('Mail with tags').build_input_mail() + self.pixelated_mailboxes.inbox().add(mail) + self.post_tags(mail.ident, self._tags_json(['INBOX', 'IMPORTANT'])) + + mails = self.get_mails_by_tag('inbox') + self.assertEquals({'inbox', 'important'}, set(mails[0].tags)) + + mails = self.get_mails_by_tag('important') + self.assertEquals('Mail with tags', mails[0].subject) + + diff --git a/service/pixelated/adapter/pixelated_mailboxes.py b/service/pixelated/adapter/pixelated_mailboxes.py index acfdf8fd..ff1aa421 100644 --- a/service/pixelated/adapter/pixelated_mailboxes.py +++ b/service/pixelated/adapter/pixelated_mailboxes.py @@ -27,6 +27,9 @@ class PixelatedMailBoxes(): self.account.addMailbox(mailbox_name) return PixelatedMailbox.create(mailbox_name) + def inbox(self): + return self._create_or_get('INBOX') + def drafts(self): return self._create_or_get('DRAFTS') |