summaryrefslogtreecommitdiff
path: root/service/test
diff options
context:
space:
mode:
Diffstat (limited to 'service/test')
-rw-r--r--service/test/unit/adapter/test_soledad_querier.py51
1 files changed, 40 insertions, 11 deletions
diff --git a/service/test/unit/adapter/test_soledad_querier.py b/service/test/unit/adapter/test_soledad_querier.py
index 160cb767..e15484d4 100644
--- a/service/test/unit/adapter/test_soledad_querier.py
+++ b/service/test/unit/adapter/test_soledad_querier.py
@@ -13,19 +13,24 @@
#
# You should have received a copy of the GNU Affero General Public License
# along with Pixelated. If not, see <http://www.gnu.org/licenses/>.
-import unittest
+from twisted.trial import unittest
import json
import base64
import quopri
+from uuid import uuid4
+import pixelated.adapter.soledad.soledad_facade_mixin
from pixelated.adapter.soledad.soledad_querier import SoledadQuerier
-from mockito import mock, when, any
+from mockito import mock, when, any, unstub
from twisted.internet import defer
import os
class SoledadQuerierTest(unittest.TestCase):
+ def tearDown(self):
+ unstub()
+
@defer.inlineCallbacks
def test_extract_parts(self):
soledad = mock()
@@ -135,27 +140,51 @@ class SoledadQuerierTest(unittest.TestCase):
yield call_with_bad_parameters(querier.idents_by_mailbox)
yield call_with_bad_parameters(querier.get_mbox)
- def test_get_lastuid(self):
+ def test_get_lastuid_broken(self):
+ # FIXME this is completely out of sync with the new implementation
soledad = mock()
mbox = mock()
mbox.content = {'lastuid': 0}
when(soledad).get_from_index('by-type-and-mbox', 'mbox', 'INBOX').thenReturn([mbox])
querier = SoledadQuerier(soledad)
- self.assertEquals(querier.get_lastuid(querier.get_mbox('INBOX')[0]), 0)
+ self.assertEquals(querier.get_lastuid(querier.get_mbox('INBOX')), 0)
mbox.content = {'lastuid': 1}
- self.assertEquals(querier.get_lastuid(querier.get_mbox('INBOX')[0]), 1)
+ self.assertEquals(querier.get_lastuid(querier.get_mbox('INBOX')), 1)
+
+ @defer.inlineCallbacks
+ def test_get_lastuid(self):
+ soledad = mock()
+ mbox = mock()
+ indexer = mock()
+ mbox.content = {'uuid': str(uuid4())}
+ when(soledad).get_from_index('by-type-and-mbox', 'mbox', 'INBOX').thenReturn(defer.succeed([mbox]))
+ querier = SoledadQuerier(soledad)
- def test_create_mail_increments_uid(self):
+ when(pixelated.adapter.soledad.soledad_facade_mixin).MailboxIndexer(soledad).thenReturn(indexer)
+ when(indexer).create_table(any()).thenReturn(defer.succeed(None))
+ when(indexer).get_last_uid(any()).thenReturn(defer.succeed(42))
+
+ last_uid = (yield querier.get_lastuid('INBOX'))
+
+ self.assertEquals(42, last_uid)
+
+ @defer.inlineCallbacks
+ def test_create_mail(self):
soledad = mock()
mbox = mock()
mail = mock()
+ indexer = mock()
+ mbox.content = {'uuid': 'some uuid'}
when(mail).get_for_save(next_uid=any(), mailbox='INBOX').thenReturn([])
- mbox.content = {'lastuid': 0}
- when(soledad).get_from_index('by-type-and-mbox', 'mbox', 'INBOX').thenReturn([mbox])
+ when(soledad).get_from_index('by-type-and-mbox', 'mbox', 'INBOX').thenReturn(defer.succeed([mbox]))
querier = SoledadQuerier(soledad)
when(querier).mail(any()).thenReturn([])
- self.assertEquals(querier.get_lastuid(querier.get_mbox('INBOX')[0]), 0)
- querier.create_mail(mail, 'INBOX')
- self.assertEquals(querier.get_lastuid(querier.get_mbox('INBOX')[0]), 1)
+ when(pixelated.adapter.soledad.soledad_facade_mixin).MailboxIndexer(soledad).thenReturn(indexer)
+ when(indexer).create_table(any()).thenReturn('')
+ when(indexer).get_last_uid('some uuid').thenReturn(defer.succeed(42))
+
+ mail_result = yield querier.create_mail(mail, 'INBOX')
+
+ self.assertEquals([], mail_result)