diff options
Diffstat (limited to 'service')
-rw-r--r-- | service/pixelated/adapter/mailstore/searchable_mailstore.py | 7 | ||||
-rw-r--r-- | service/test/unit/adapter/mailstore/test_searchable_mailstore.py | 37 |
2 files changed, 35 insertions, 9 deletions
diff --git a/service/pixelated/adapter/mailstore/searchable_mailstore.py b/service/pixelated/adapter/mailstore/searchable_mailstore.py index ad5fca33..1db34fd9 100644 --- a/service/pixelated/adapter/mailstore/searchable_mailstore.py +++ b/service/pixelated/adapter/mailstore/searchable_mailstore.py @@ -13,6 +13,7 @@ # # 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 twisted.internet import defer from pixelated.adapter.mailstore.mailstore import MailStore @@ -22,6 +23,8 @@ class SearchableMailStore(MailStore): self._delegate = delegate self._search_engine = search_engine + @defer.inlineCallbacks def add_mail(self, mailbox_name, mail): - self._delegate.add_mail(mailbox_name, mail) - self._search_engine.index_mail(mail) + stored_mail = yield self._delegate.add_mail(mailbox_name, mail) + self._search_engine.index_mail(stored_mail) + defer.returnValue(stored_mail) diff --git a/service/test/unit/adapter/mailstore/test_searchable_mailstore.py b/service/test/unit/adapter/mailstore/test_searchable_mailstore.py index 9ba61e32..f486a8e2 100644 --- a/service/test/unit/adapter/mailstore/test_searchable_mailstore.py +++ b/service/test/unit/adapter/mailstore/test_searchable_mailstore.py @@ -15,24 +15,46 @@ # along with Pixelated. If not, see <http://www.gnu.org/licenses/>. from email.parser import Parser import os -from mockito import verify, mock +from mockito import verify, mock, when import pkg_resources +from twisted.internet import defer from twisted.trial.unittest import TestCase +from pixelated.adapter.mailstore.leap_mailstore import LeapMail from pixelated.adapter.mailstore.searchable_mailstore import SearchableMailStore from pixelated.adapter.search import SearchEngine +ANY_MAILBOX = 'INBOX' + + class TestLeapMail(TestCase): + + def setUp(self): + super(TestLeapMail, self).setUp() + self.search_index = mock(mocked_obj=SearchEngine) + self.delegate_mail_store = mock() + self.store = SearchableMailStore(self.delegate_mail_store, self.search_index) + + @defer.inlineCallbacks def test_add_mail_delegates_to_mail_store_and_updates_index(self): mail = self._load_mail_from_file('mbox00000000') - search_index = mock(mocked_obj=SearchEngine) - delegate_mail_store = mock() - store = SearchableMailStore(delegate_mail_store, search_index) + leap_mail = LeapMail('id', ANY_MAILBOX) + when(self.delegate_mail_store).add_mail(ANY_MAILBOX, mail).thenReturn(defer.succeed(leap_mail)) - store.add_mail('INBOX', mail) + yield self.store.add_mail(ANY_MAILBOX, mail) - verify(search_index).index_mail(mail) - verify(delegate_mail_store).add_mail('INBOX', mail) + verify(self.delegate_mail_store).add_mail(ANY_MAILBOX, mail) + verify(self.search_index).index_mail(leap_mail) + + @defer.inlineCallbacks + def test_add_mail_returns_stored_mail(self): + mail = self._load_mail_from_file('mbox00000000') + leap_mail = LeapMail('id', ANY_MAILBOX) + when(self.delegate_mail_store).add_mail(ANY_MAILBOX, mail).thenReturn(defer.succeed(leap_mail)) + + result = yield self.store.add_mail(ANY_MAILBOX, mail) + + self.assertEqual(leap_mail, result) def _load_mail_from_file(self, mail_file): mailset_dir = pkg_resources.resource_filename('test.unit.fixtures', 'mailset') @@ -40,3 +62,4 @@ class TestLeapMail(TestCase): with open(mail_file) as f: mail = Parser().parse(f) return mail + |