summaryrefslogtreecommitdiff
path: root/service/test/integration/test_mark_as_read_unread.py
diff options
context:
space:
mode:
authorDuda Dornelles <dudassdornelles@gmail.com>2015-01-22 10:25:40 -0200
committerPixpoa pairing <pixpoapairing@pixelated-project.org>2015-01-22 10:42:48 -0200
commita8274b633a62262e65c7d013e61a54541ce07bf8 (patch)
treeab3172f3fd1ffe9311bd5f1f2b0ccc139bbc14d1 /service/test/integration/test_mark_as_read_unread.py
parent137f1f103cf1bfb76c7e62f2ee9df21d2d1f6223 (diff)
#224 renaming tests so they get caught by trial runner
Diffstat (limited to 'service/test/integration/test_mark_as_read_unread.py')
-rw-r--r--service/test/integration/test_mark_as_read_unread.py104
1 files changed, 104 insertions, 0 deletions
diff --git a/service/test/integration/test_mark_as_read_unread.py b/service/test/integration/test_mark_as_read_unread.py
new file mode 100644
index 00000000..86a48e62
--- /dev/null
+++ b/service/test/integration/test_mark_as_read_unread.py
@@ -0,0 +1,104 @@
+#
+# 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/>.
+
+from test.support.integration import *
+from pixelated.adapter.model.status import Status
+
+
+class MarkAsReadUnreadTest(SoledadTestBase):
+
+ def setUp(self):
+ SoledadTestBase.setUp(self)
+
+ def tearDown(self):
+ SoledadTestBase.tearDown(self)
+
+ def test_mark_single_as_read(self):
+ input_mail = MailBuilder().build_input_mail()
+ self.client.add_mail_to_inbox(input_mail)
+
+ mails = self.get_mails_by_tag('inbox')
+ self.assertNotIn('read', mails[0].status)
+
+ self.mark_many_as_read([input_mail.ident])
+
+ mails = self.get_mails_by_tag('inbox')
+ self.assertIn('read', mails[0].status)
+
+ def test_mark_single_as_unread(self):
+ input_mail = MailBuilder().with_status([Status.SEEN]).build_input_mail()
+ self.client.add_mail_to_inbox(input_mail)
+
+ self.mark_many_as_unread([input_mail.ident])
+ mail = self.get_mails_by_tag('inbox')[0]
+
+ self.assertNotIn('read', mail.status)
+
+ def test_mark_many_mails_as_unread(self):
+ input_mail = MailBuilder().with_status([Status.SEEN]).build_input_mail()
+ input_mail2 = MailBuilder().with_status([Status.SEEN]).build_input_mail()
+
+ self.client.add_mail_to_inbox(input_mail)
+ self.client.add_mail_to_inbox(input_mail2)
+
+ self.mark_many_as_unread([input_mail.ident, input_mail2.ident])
+
+ mails = self.get_mails_by_tag('inbox')
+
+ self.assertNotIn('read', mails[0].status)
+ self.assertNotIn('read', mails[1].status)
+
+ def test_mark_many_mails_as_read(self):
+ input_mail = MailBuilder().build_input_mail()
+ input_mail2 = MailBuilder().build_input_mail()
+
+ self.client.add_mail_to_inbox(input_mail)
+ self.client.add_mail_to_inbox(input_mail2)
+
+ mails = self.get_mails_by_tag('inbox')
+
+ self.assertNotIn('read', mails[0].status)
+ self.assertNotIn('read', mails[1].status)
+
+ response = self.mark_many_as_read([input_mail.ident, input_mail2.ident])
+ self.assertEquals(200, response.code)
+
+ mails = self.get_mails_by_tag('inbox')
+
+ self.assertIn('read', mails[0].status)
+ self.assertIn('read', mails[1].status)
+
+ def test_mark_mixed_status_as_read(self):
+ input_mail = MailBuilder().build_input_mail()
+ input_mail2 = MailBuilder().with_status([Status.SEEN]).build_input_mail()
+
+ self.client.add_mail_to_inbox(input_mail)
+ self.client.add_mail_to_inbox(input_mail2)
+
+ mails = self.get_mails_by_tag('inbox')
+
+ read_mails = filter(lambda x: 'read' in x.status, mails)
+ unread_mails = filter(lambda x: 'read' not in x.status, mails)
+ self.assertEquals(1, len(unread_mails))
+ self.assertEquals(1, len(read_mails))
+
+ response = self.mark_many_as_read([input_mail.ident, input_mail2.ident])
+ self.assertEquals(200, response.code)
+
+ mails = self.get_mails_by_tag('inbox')
+
+ self.assertIn('read', mails[0].status)
+ self.assertIn('read', mails[1].status)