diff options
author | Alexandre Pretto Nunes <anunes@thoughtworks.com> | 2014-10-23 13:57:03 -0200 |
---|---|---|
committer | Alexandre Pretto Nunes <anunes@thoughtworks.com> | 2014-10-23 13:57:15 -0200 |
commit | 7005b03934b2b666b56fb972cfad057a46d2fcbd (patch) | |
tree | e85076e03d3814f5b041cdbb1130299203084ce1 | |
parent | 1ae0823828e45b16b8788c78011346ef7316545e (diff) |
Add tests for the mails controller
-rw-r--r-- | service/test/unit/controllers/mails_controller_test.py | 34 |
1 files changed, 32 insertions, 2 deletions
diff --git a/service/test/unit/controllers/mails_controller_test.py b/service/test/unit/controllers/mails_controller_test.py index ce2ce539..8807cc72 100644 --- a/service/test/unit/controllers/mails_controller_test.py +++ b/service/test/unit/controllers/mails_controller_test.py @@ -23,12 +23,12 @@ class TestMailsController(unittest.TestCase): def setUp(self): self.mail_service = mock() - search_engine = mock() + self.search_engine = mock() draft_service = mock() self.mails_controller = MailsController(mail_service=self.mail_service, draft_service=draft_service, - search_engine=search_engine) + search_engine=self.search_engine) self.input_mail = mock() self.input_mail.json = {'header': {'from': 'a@a.a', 'to': 'b@b.b'}, @@ -57,6 +57,36 @@ class TestMailsController(unittest.TestCase): self.assertEqual(result.status_code, 422) self.assertEqual(result.data, '{"message": "email sending failed\\nmore information of error\\n123\\nthere was a code before this"}') + def test_fetching_mail_gets_mail_from_mail_service(self): + mail = mock() + mail.as_dict = lambda: {'ident': 1, 'body': 'le mail body'} + when(self.mail_service).mail(1).thenReturn(mail) + + response = self.mails_controller.mail(1) + + verify(self.mail_service).mail(1) + self.assertEqual(response.data, '{"body": "le mail body", "ident": 1}') + + def test_marking_mail_as_read_set_mail_as_read_on_the_service(self): + mail = mock() + when(self.mail_service).mark_as_read(1).thenReturn(mail) + when(self.search_engine).index_mail(mail).thenReturn(None) + + self.mails_controller.mark_mail_as_read(1) + + verify(self.mail_service).mark_as_read(1) + verify(self.search_engine).index_mail(mail) + + def test_marking_mail_as_unread_set_mail_as_unread_on_the_service(self): + mail = mock() + when(self.mail_service).mark_as_unread(1).thenReturn(mail) + when(self.search_engine).index_mail(mail).thenReturn(None) + + self.mails_controller.mark_mail_as_unread(1) + + verify(self.mail_service).mark_as_unread(1) + verify(self.search_engine).index_mail(mail) + def _successfuly_send_mail(self, ident, mail): sent_mail = mock() sent_mail.as_dict = lambda: self.input_mail.json |