diff options
-rw-r--r-- | service/test/integration/test_contacts.py | 83 |
1 files changed, 37 insertions, 46 deletions
diff --git a/service/test/integration/test_contacts.py b/service/test/integration/test_contacts.py index 1d82b0d7..a838e15b 100644 --- a/service/test/integration/test_contacts.py +++ b/service/test/integration/test_contacts.py @@ -14,52 +14,48 @@ # 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 SoledadTestBase, MailBuilder +from twisted.internet import defer import os import json class ContactsTest(SoledadTestBase): + @defer.inlineCallbacks def test_TO_CC_and_BCC_fields_are_being_searched(self): input_mail = MailBuilder().with_tags(['important']).build_input_mail() - self.add_mail_to_inbox(input_mail) + yield self.add_mail_to_inbox(input_mail) - d = self.get_contacts(query='recipient') + contacts = yield self.get_contacts(query='recipient') - def _assert(contacts): - self.assertTrue('recipient@to.com' in contacts) - self.assertTrue('recipient@cc.com' in contacts) - self.assertTrue('recipient@bcc.com' in contacts) - d.addCallback(_assert) - return d + self.assertTrue('recipient@to.com' in contacts) + self.assertTrue('recipient@cc.com' in contacts) + self.assertTrue('recipient@bcc.com' in contacts) + @defer.inlineCallbacks def test_FROM_address_is_being_searched(self): input_mail = MailBuilder().with_tags(['important']).build_input_mail() - self.add_mail_to_inbox(input_mail) + yield self.add_mail_to_inbox(input_mail) - d = self.get_contacts(query='Sender') + contacts = yield self.get_contacts(query='Sender') - def _assert(contacts): - self.assertIn('Formatted Sender <sender@from.com>', contacts) - d.addCallback(_assert) - return d + self.assertIn('Formatted Sender <sender@from.com>', contacts) + @defer.inlineCallbacks def test_trash_and_drafts_mailboxes_are_being_ignored(self): - self.add_multiple_to_mailbox(1, mailbox='INBOX', to='recipient@inbox.com') - self.add_multiple_to_mailbox(1, mailbox='DRAFTS', to='recipient@drafts.com') - self.add_multiple_to_mailbox(1, mailbox='SENT', to='recipient@sent.com') - self.add_multiple_to_mailbox(1, mailbox='TRASH', to='recipient@trash.com') + yield self.add_multiple_to_mailbox(1, mailbox='INBOX', to='recipient@inbox.com') + yield self.add_multiple_to_mailbox(1, mailbox='DRAFTS', to='recipient@drafts.com') + yield self.add_multiple_to_mailbox(1, mailbox='SENT', to='recipient@sent.com') + yield self.add_multiple_to_mailbox(1, mailbox='TRASH', to='recipient@trash.com') - d = self.get_contacts(query='recipient') + contacts = yield self.get_contacts(query='recipient') - def _assert(contacts): - self.assertTrue('recipient@inbox.com' in contacts) - self.assertTrue('recipient@sent.com' in contacts) - self.assertFalse('recipient@drafts.com' in contacts) - self.assertFalse('recipient@trash.com' in contacts) - d.addCallback(_assert) - return d + self.assertTrue('recipient@inbox.com' in contacts) + self.assertTrue('recipient@sent.com' in contacts) + self.assertFalse('recipient@drafts.com' in contacts) + self.assertFalse('recipient@trash.com' in contacts) + @defer.inlineCallbacks def test_deduplication_on_same_mail_address_using_largest(self): input_mail = MailBuilder().with_tags(['important']).build_input_mail() @@ -69,41 +65,36 @@ class ContactsTest(SoledadTestBase): formatted_input_mail.with_bcc('Recipient Carbon <recipient@bcc.com>') formatted_input_mail = formatted_input_mail.build_input_mail() - self.add_mail_to_inbox(input_mail) - self.add_mail_to_inbox(formatted_input_mail) + yield self.add_mail_to_inbox(input_mail) + yield self.add_mail_to_inbox(formatted_input_mail) - d = self.get_contacts(query='Recipient') + contacts = yield self.get_contacts(query='Recipient') - def _assert(contacts): - self.assertEquals(3, len(contacts)) - self.assertTrue('Recipient Principal <recipient@to.com>' in contacts) - self.assertTrue('Recipient Copied <recipient@cc.com>' in contacts) - self.assertTrue('Recipient Carbon <recipient@bcc.com>' in contacts) - d.addCallback(_assert) - return d + self.assertEquals(3, len(contacts)) + self.assertTrue('Recipient Principal <recipient@to.com>' in contacts) + self.assertTrue('Recipient Copied <recipient@cc.com>' in contacts) + self.assertTrue('Recipient Carbon <recipient@bcc.com>' in contacts) + @defer.inlineCallbacks def test_bounced_addresses_are_ignored(self): to_be_bounced = MailBuilder().with_to('this_mail_was_bounced@domain.com').build_input_mail() - self.add_mail_to_inbox(to_be_bounced) + yield self.add_mail_to_inbox(to_be_bounced) bounced_mail_template = MailBuilder().build_input_mail() - bounced_mail = self.mailboxes.inbox.add(bounced_mail_template) + bounced_mail = yield (yield self.mailboxes.inbox).add(bounced_mail_template) bounced_mail.hdoc.content = self._bounced_mail_hdoc_content() bounced_mail.save() self.search_engine.index_mail(bounced_mail) not_bounced_mail = MailBuilder( ).with_tags(['important']).with_to('this_mail_was_not@bounced.com').build_input_mail() - self.add_mail_to_inbox(not_bounced_mail) + yield self.add_mail_to_inbox(not_bounced_mail) - d = self.get_contacts(query='this') + contacts = yield self.get_contacts(query='this') - def _assert(contacts): - self.assertNotIn('this_mail_was_bounced@domain.com', contacts) - self.assertNotIn("MAILER-DAEMON@domain.org (Mail Delivery System)", contacts) - self.assertIn('this_mail_was_not@bounced.com', contacts) - d.addCallback(_assert) - return d + self.assertNotIn('this_mail_was_bounced@domain.com', contacts) + self.assertNotIn("MAILER-DAEMON@domain.org (Mail Delivery System)", contacts) + self.assertIn('this_mail_was_not@bounced.com', contacts) def _bounced_mail_hdoc_content(self): hdoc_file = os.path.join(os.path.dirname(__file__), '..', 'unit', 'fixtures', 'bounced_mail_hdoc.json') |