From b2334df7a677047749d411dda4cd4cd58474ee8a Mon Sep 17 00:00:00 2001 From: Duda Dornelles Date: Wed, 15 Oct 2014 16:39:32 +0200 Subject: getting rid of "pixelated" in the names of many classes - redundant --- .../unit/adapter/mailbox_indexer_listener_test.py | 54 ++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 service/test/unit/adapter/mailbox_indexer_listener_test.py (limited to 'service/test/unit/adapter/mailbox_indexer_listener_test.py') diff --git a/service/test/unit/adapter/mailbox_indexer_listener_test.py b/service/test/unit/adapter/mailbox_indexer_listener_test.py new file mode 100644 index 00000000..1f28ec7b --- /dev/null +++ b/service/test/unit/adapter/mailbox_indexer_listener_test.py @@ -0,0 +1,54 @@ +# +# 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 . +import unittest + +from mockito import * +from pixelated.adapter.mailbox_indexer_listener import MailboxIndexerListener + + +class MailboxListenerTest(unittest.TestCase): + def setUp(self): + self.querier = mock() + self.account = mock() + self.account.mailboxes = [] + + def test_add_itself_to_mailbox_listeners(self): + self.account.mailboxes = ['INBOX'] + mailbox = mock() + when(self.account).getMailbox('INBOX').thenReturn(mailbox) + mailbox.listeners = set() + when(mailbox).addListener = lambda x: mailbox.listeners.add(x) + + self.assertNotIn(MailboxIndexerListener('INBOX', self.querier), mailbox.listeners) + + MailboxIndexerListener.listen(self.account, 'INBOX', self.querier) + + self.assertIn(MailboxIndexerListener('INBOX', self.querier), mailbox.listeners) + + def test_reindex_missing_idents(self): + search_engine = mock() + when(search_engine).search('tag:inbox').thenReturn(['ident1', 'ident2']) + + MailboxIndexerListener.SEARCH_ENGINE = search_engine + + listener = MailboxIndexerListener('INBOX', self.querier) + when(self.querier).idents_by_mailbox('INBOX').thenReturn({'ident1', 'ident2', 'missing_ident'}) + self.querier.used_arguments = [] + self.querier.mails = lambda x: self.querier.used_arguments.append(x) + listener.newMessages(10, 5) + + verify(self.querier, times=1).idents_by_mailbox('INBOX') + self.assertIn({'missing_ident'}, self.querier.used_arguments) -- cgit v1.2.3