summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--service/integration/__init__.py4
-rw-r--r--service/integration/delete_mail_test.py40
-rw-r--r--service/integration/tags_test.py1
-rw-r--r--service/pixelated/adapter/mail_service.py3
-rw-r--r--service/pixelated/adapter/pixelated_mail.py6
-rw-r--r--service/pixelated/adapter/pixelated_mailbox.py8
-rw-r--r--service/pixelated/adapter/pixelated_mailboxes.py7
-rw-r--r--service/pixelated/adapter/soledad_querier.py1
-rw-r--r--service/test/adapter/mail_service_test.py5
-rw-r--r--service/test/adapter/pixelated_mailbox_test.py2
10 files changed, 64 insertions, 13 deletions
diff --git a/service/integration/__init__.py b/service/integration/__init__.py
index c4e1d0b4..a9991f6f 100644
--- a/service/integration/__init__.py
+++ b/service/integration/__init__.py
@@ -102,7 +102,6 @@ class MailBuilder:
return InputMail.from_dict(self.mail)
-
class SoledadTestBase:
def teardown_soledad(self):
@@ -142,6 +141,9 @@ class SoledadTestBase:
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)
+ def delete_mail(self, mail_ident):
+ self.app.delete('/mail/' + mail_ident)
+
class ResponseMail:
diff --git a/service/integration/delete_mail_test.py b/service/integration/delete_mail_test.py
new file mode 100644
index 00000000..e7e08c31
--- /dev/null
+++ b/service/integration/delete_mail_test.py
@@ -0,0 +1,40 @@
+#
+# 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 MailBuilder, SoledadTestBase
+
+
+class DeleteMailTest(unittest.TestCase, SoledadTestBase):
+
+ def setUp(self):
+ self.setup_soledad()
+
+ def tearDown(self):
+ self.teardown_soledad()
+
+ def test_move_mail_to_trash_when_deleting(self):
+ mail = MailBuilder().with_subject('Mail with tags').build_input_mail()
+ self.pixelated_mailboxes.inbox().add(mail)
+
+ inbox_mails = self.get_mails_by_tag('inbox')
+ self.assertEquals(1, len(inbox_mails))
+
+ self.delete_mail(mail.ident)
+
+ inbox_mails = self.get_mails_by_tag('inbox')
+ self.assertEquals(0, len(inbox_mails))
+ trash_mails = self.get_mails_by_tag('trash')
+ self.assertEquals(1, len(trash_mails))
diff --git a/service/integration/tags_test.py b/service/integration/tags_test.py
index 8971fac7..a0743b6a 100644
--- a/service/integration/tags_test.py
+++ b/service/integration/tags_test.py
@@ -32,6 +32,7 @@ class TagsTest(unittest.TestCase, SoledadTestBase):
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')
diff --git a/service/pixelated/adapter/mail_service.py b/service/pixelated/adapter/mail_service.py
index 0d3e00f7..c216e7ae 100644
--- a/service/pixelated/adapter/mail_service.py
+++ b/service/pixelated/adapter/mail_service.py
@@ -74,8 +74,7 @@ class MailService:
raise NotImplementedError()
def delete_mail(self, mail_id):
- _mail = self.mailboxes.mail(mail_id)
- return self.mailboxes.move_to_trash(_mail)
+ return self.mailboxes.move_to_trash(mail_id)
def save_draft(self, draft):
raise NotImplementedError()
diff --git a/service/pixelated/adapter/pixelated_mail.py b/service/pixelated/adapter/pixelated_mail.py
index b7323af9..3e0f1ee0 100644
--- a/service/pixelated/adapter/pixelated_mail.py
+++ b/service/pixelated/adapter/pixelated_mail.py
@@ -215,6 +215,12 @@ class PixelatedMail:
def save(self):
return self.querier.save_mail(self)
+ def set_mailbox(self, mailbox_name):
+ self.fdoc.content['mbox'] = mailbox_name
+
+ def set_recent(self):
+ self.fdoc.content['flags'].append("\\Recent")
+
def set_from(self, _from):
self.headers['From'] = [_from]
diff --git a/service/pixelated/adapter/pixelated_mailbox.py b/service/pixelated/adapter/pixelated_mailbox.py
index 85d965d1..62ea57e6 100644
--- a/service/pixelated/adapter/pixelated_mailbox.py
+++ b/service/pixelated/adapter/pixelated_mailbox.py
@@ -54,8 +54,16 @@ class PixelatedMailbox:
def add(self, mail):
self.querier.create_mail(mail, self.mailbox_name)
+ def add_existing(self, mail_ident):
+ mail = self.querier.mail(mail_ident)
+ mail.remove_all_tags()
+ mail.set_mailbox(self.mailbox_name)
+ mail.save()
+ self.add_mailbox_tag_if_not_there(mail)
+
def remove(self, ident):
mail = self.querier.mail(ident)
+ mail.remove_all_tags()
self.querier.remove_mail(mail)
@classmethod
diff --git a/service/pixelated/adapter/pixelated_mailboxes.py b/service/pixelated/adapter/pixelated_mailboxes.py
index ff1aa421..aa39a5c4 100644
--- a/service/pixelated/adapter/pixelated_mailboxes.py
+++ b/service/pixelated/adapter/pixelated_mailboxes.py
@@ -60,11 +60,8 @@ class PixelatedMailBoxes():
self.drafts().remove(ident)
return new_mail
- def move_to_trash(self, mail):
- origin_mailbox = mail.mailbox_name
-
- new_mail_id = self.trash().add(mail)
- self._create_or_get(origin_mailbox).remove(mail)
+ def move_to_trash(self, mail_id):
+ new_mail_id = self.trash().add_existing(mail_id)
return new_mail_id
def mail(self, mail_id):
diff --git a/service/pixelated/adapter/soledad_querier.py b/service/pixelated/adapter/soledad_querier.py
index 7ce7f26d..61bada1a 100644
--- a/service/pixelated/adapter/soledad_querier.py
+++ b/service/pixelated/adapter/soledad_querier.py
@@ -57,6 +57,7 @@ class SoledadQuerier:
# XXX update only what has to be updated
self.soledad.put_doc(mail.fdoc)
self.soledad.put_doc(mail.hdoc)
+ self._update_index([mail.fdoc, mail.hdoc])
def create_mail(self, mail, mailbox_name):
uid = self._next_uid_for_mailbox(mailbox_name)
diff --git a/service/test/adapter/mail_service_test.py b/service/test/adapter/mail_service_test.py
index 7912241d..549ab05c 100644
--- a/service/test/adapter/mail_service_test.py
+++ b/service/test/adapter/mail_service_test.py
@@ -55,9 +55,6 @@ class TestMailService(unittest.TestCase):
verify(self.mailboxes).add_draft(mail)
def test_delete_mail(self):
- mail = mock()
- when(self.mailboxes).mail(any()).thenReturn(mail)
-
self.mail_service.delete_mail(1)
- verify(self.mailboxes).move_to_trash(mail)
+ verify(self.mailboxes).move_to_trash(1)
diff --git a/service/test/adapter/pixelated_mailbox_test.py b/service/test/adapter/pixelated_mailbox_test.py
index 87f7b4f3..5b1cfae5 100644
--- a/service/test/adapter/pixelated_mailbox_test.py
+++ b/service/test/adapter/pixelated_mailbox_test.py
@@ -40,7 +40,7 @@ class PixelatedMailboxTest(unittest.TestCase):
self.assertNotIn('spam', self.mailbox.mails()[0].tags)
def test_remove_message_from_mailbox(self):
- mail = PixelatedMail()
+ mail = PixelatedMail.from_soledad(*test_helper.leap_mail(), soledad_querier=self.querier)
when(self.querier).mail(1).thenReturn(mail)
self.mailbox.remove(1)