diff options
-rw-r--r-- | service/integration/__init__.py | 50 | ||||
-rw-r--r-- | service/integration/drafts_test.py | 53 | ||||
-rw-r--r-- | service/integration/mail_fetch_test.py | 25 | ||||
-rw-r--r-- | service/pixelated/adapter/pixelated_mail.py | 8 | ||||
-rw-r--r-- | service/pixelated/adapter/pixelated_mailboxes.py | 2 | ||||
-rw-r--r-- | service/pixelated/adapter/soledad_querier.py | 2 | ||||
-rw-r--r-- | service/pixelated/user_agent.py | 11 |
7 files changed, 102 insertions, 49 deletions
diff --git a/service/integration/__init__.py b/service/integration/__init__.py index 717fa3e9..aff5cec0 100644 --- a/service/integration/__init__.py +++ b/service/integration/__init__.py @@ -21,6 +21,8 @@ import os from mock import Mock import shutil 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_mailboxes import PixelatedMailBoxes @@ -89,34 +91,60 @@ class JSONMailBuilder: self.mail['header']['subject'] = subject return self + def with_ident(self, ident): + self.mail['ident'] = ident + return self + def build(self): return json.dumps(self.mail) class SoledadTestBase: - def __init__(self): - pass - def teardown_soledad(self): self.soledad.close() shutil.rmtree(soledad_test_folder) def setup_soledad(self): - self.app = pixelated.user_agent.app.test_client() - self.account = FakeAccount() - self.mail_sender = mock() - self.mail_address = "test@pixelated.org" self.soledad = initialize_soledad(tempdir=soledad_test_folder) + self.mail_address = "test@pixelated.org" SoledadQuerier.instance = None SoledadQuerier.get_instance(soledad=self.soledad) PixelatedMail.from_email_address = self.mail_address - pixelated_mailboxes = PixelatedMailBoxes(self.account) - pixelated.user_agent.mail_service = MailService(pixelated_mailboxes, self.mail_sender) + + self.app = pixelated.user_agent.app.test_client() + self.account = FakeAccount() + self.mail_sender = mock() + self.tag_index = TagIndex(os.path.join(soledad_test_folder, 'tag_index')) + self.tag_service = TagService(self.tag_index) + self.pixelated_mailboxes = PixelatedMailBoxes(self.account) + self.mail_service = MailService(self.pixelated_mailboxes, self.mail_sender, self.tag_service) + + pixelated.user_agent.mail_service = self.mail_service def get_mails_by_tag(self, tag): - return json.loads(self.app.get("/mails?q=tag" + tag).data) + response = json.loads(self.app.get("/mails?q=tag:" + tag).data) + return [ResponseMail(m) for m in response['mails']] def post_mail(self, data): - self.app.post('/mails', data=data, content_type="application/json")
\ No newline at end of file + response = json.loads(self.app.post('/mails', data=data, content_type="application/json").data) + return ResponseMail(response) + + +class ResponseMail: + + def __init__(self, mail_dict): + self.mail_dict = mail_dict + + @property + def subject(self): + return self.headers['subject'] + + @property + def headers(self): + return self.mail_dict['header'] + + @property + def ident(self): + return self.mail_dict['ident']
\ No newline at end of file diff --git a/service/integration/drafts_test.py b/service/integration/drafts_test.py new file mode 100644 index 00000000..1f1712a8 --- /dev/null +++ b/service/integration/drafts_test.py @@ -0,0 +1,53 @@ +# +# 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 integration import JSONMailBuilder, SoledadTestBase + + +class DraftsTest(unittest.TestCase, SoledadTestBase): + + def setUp(self): + self.setup_soledad() + + def tearDown(self): + self.teardown_soledad() + + def test_post_creates_a_draft_when_data_has_no_ident(self): + mail = JSONMailBuilder().with_subject('A new draft').build() + + self.post_mail(mail) + mails = self.get_mails_by_tag('drafts') + + 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_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() + self.post_mail(second_draft) + + sent_mails = self.get_mails_by_tag('sent') + drafts = self.get_mails_by_tag('drafts') + + import pdb;pdb.set_trace() + + self.assertEquals(1, len(sent_mails)) + self.assertEquals('Second draft', sent_mails[0].subject) + self.assertEquals(0, len(drafts)) + + diff --git a/service/integration/mail_fetch_test.py b/service/integration/mail_fetch_test.py deleted file mode 100644 index 882e9d6f..00000000 --- a/service/integration/mail_fetch_test.py +++ /dev/null @@ -1,25 +0,0 @@ -import unittest - -from integration import JSONMailBuilder, SoledadTestBase - - -class MailFetchTest(unittest.TestCase, SoledadTestBase): - - def setUp(self): - self.setup_soledad() - - def tearDown(self): - self.teardown_soledad() - - def test_get_mails(self): - mail_one = JSONMailBuilder().with_subject("Mail One").build() - mail_two = JSONMailBuilder().with_subject("Mail Two").build() - - self.post_mail(mail_one) - self.post_mail(mail_two) - - response = self.get_mails_by_tag("drafts") - - # ordered by creation date - self.assertEquals(u'Mail Two', response['mails'][0]['header']['subject']) - self.assertEquals(u'Mail One', response['mails'][1]['header']['subject']) diff --git a/service/pixelated/adapter/pixelated_mail.py b/service/pixelated/adapter/pixelated_mail.py index 89320b75..b7323af9 100644 --- a/service/pixelated/adapter/pixelated_mail.py +++ b/service/pixelated/adapter/pixelated_mail.py @@ -77,17 +77,17 @@ class InputMail: self._chash = sha256.SHA256(self._raw()).hexdigest() return self._chash - def _get_for_save(self, next_uid): - docs = [self._fdoc(next_uid), self._hdoc()] + def _get_for_save(self, next_uid, mailbox): + docs = [self._fdoc(next_uid, mailbox), self._hdoc()] docs.extend([m for m in self._cdocs()]) return docs - def _fdoc(self, next_uid): + def _fdoc(self, next_uid, mailbox): if self._fd: return self._fd fd = {} - fd[fields.MBOX_KEY] = 'DRAFTS' + fd[fields.MBOX_KEY] = mailbox fd[fields.UID_KEY] = next_uid fd[fields.CONTENT_HASH_KEY] = self._get_chash() fd[fields.SIZE_KEY] = len(self._raw()) diff --git a/service/pixelated/adapter/pixelated_mailboxes.py b/service/pixelated/adapter/pixelated_mailboxes.py index 9180dd8d..acfdf8fd 100644 --- a/service/pixelated/adapter/pixelated_mailboxes.py +++ b/service/pixelated/adapter/pixelated_mailboxes.py @@ -34,7 +34,7 @@ class PixelatedMailBoxes(): return self._create_or_get('TRASH') def sent(self): - return self._create_or_get('TRASH') + return self._create_or_get('SENT') @property def mailboxes(self): diff --git a/service/pixelated/adapter/soledad_querier.py b/service/pixelated/adapter/soledad_querier.py index 7f617767..7ce7f26d 100644 --- a/service/pixelated/adapter/soledad_querier.py +++ b/service/pixelated/adapter/soledad_querier.py @@ -60,7 +60,7 @@ class SoledadQuerier: def create_mail(self, mail, mailbox_name): uid = self._next_uid_for_mailbox(mailbox_name) - new_docs = [self.soledad.create_doc(doc) for doc in mail._get_for_save(next_uid=uid)] + new_docs = [self.soledad.create_doc(doc) for doc in mail._get_for_save(next_uid=uid, mailbox=mailbox_name)] self._update_index(new_docs) def mail(self, ident): diff --git a/service/pixelated/user_agent.py b/service/pixelated/user_agent.py index 8651a822..2dc71bf0 100644 --- a/service/pixelated/user_agent.py +++ b/service/pixelated/user_agent.py @@ -60,14 +60,11 @@ def disabled_features(): @app.route('/mails', methods=['POST']) def send_mail(): _mail = InputMail.from_dict(request.json) - if 'saveDraft' in DISABLED_FEATURES: - mail_service.send(_mail) + draft_id = request.json.get('ident') + if draft_id: + mail_service.send(draft_id, _mail) else: - draft_id = request.json.get('ident') - if draft_id: - mail_service.send(draft_id, _mail) - else: - _mail = mail_service.create_draft(_mail) + _mail = mail_service.create_draft(_mail) return respond_json(_mail.as_dict()) |