[tor-commits] [bridgedb/develop] Add unittests for SQL to determine which distributor to allocate to.

isis at torproject.org isis at torproject.org
Sat Oct 28 00:29:39 UTC 2017


commit 48d4562f544c0635e0ce75a4151a68ff10c6908f
Author: Isis Lovecruft <isis at torproject.org>
Date:   Fri Oct 27 23:30:24 2017 +0000

    Add unittests for SQL to determine which distributor to allocate to.
---
 bridgedb/test/test_Storage.py | 69 +++++++++++++++++++++++++++++++++++++++----
 1 file changed, 64 insertions(+), 5 deletions(-)

diff --git a/bridgedb/test/test_Storage.py b/bridgedb/test/test_Storage.py
index 8b0affd..dffba2b 100644
--- a/bridgedb/test/test_Storage.py
+++ b/bridgedb/test/test_Storage.py
@@ -1,17 +1,23 @@
 #!/usr/bin/env python
 """Unittests for the :mod:`bridgedb.Storage` module."""
 
+import os
+import threading
+import time
+
 from twisted.python import log
 from twisted.trial import unittest
-import bridgedb.Storage as Storage
 from twisted.internet import reactor
 from twisted.internet.threads import deferToThread
-import os
-import threading
-from time import sleep
+
+import bridgedb.Storage as Storage
+
+from bridgedb.test.util import generateFakeBridges
 
 class DatabaseTest(unittest.TestCase):
     def setUp(self):
+        self.fakeBridges = generateFakeBridges()
+        self.validRings = ['https', 'unallocated', 'email', 'moat']
         self.dbfname = 'test-bridgedb.sqlite'
         Storage.setDBFilename(self.dbfname)
 
@@ -22,7 +28,7 @@ class DatabaseTest(unittest.TestCase):
 
     def _runAndDie(self, timeout, func):
         with func():
-            sleep(timeout)
+            time.sleep(timeout)
 
     def _cb_assertTrue(self, result):
         self.assertTrue(result)
@@ -54,3 +60,56 @@ class DatabaseTest(unittest.TestCase):
         d2.addCallback(self._cb_assertFalse)
         d2.addErrback(self._eb_Failure)
         d2.addCallback(self._cb_assertTrue, Storage.getDB(False))
+
+    def test_insertBridgeAndGetRing_new_bridge(self):
+        bridge = self.fakeBridges[0]
+        Storage.initializeDBLock()
+        with Storage.getDB() as db:
+            ringname = db.insertBridgeAndGetRing(bridge, 'moat',
+                                                 time.time(),
+                                                 self.validRings)
+            self.assertIn(ringname, self.validRings)
+
+    def test_insertBridgeAndGetRing_already_seen_bridge(self):
+        bridge = self.fakeBridges[0]
+        Storage.initializeDBLock()
+        with Storage.getDB() as db:
+            ringname = db.insertBridgeAndGetRing(bridge, 'moat',
+                                                 time.time(),
+                                                 self.validRings)
+            self.assertIn(ringname, self.validRings)
+            ringname = db.insertBridgeAndGetRing(bridge, 'https',
+                                                 time.time(),
+                                                 self.validRings)
+            self.assertIn(ringname, self.validRings)
+            self.assertEqual(ringname, 'moat')
+
+    def test_getBridgeDistributor_recognised(self):
+        bridge = self.fakeBridges[0]
+        Storage.initializeDBLock()
+        with Storage.getDB() as db:
+            ringname = db.insertBridgeAndGetRing(bridge, 'moat',
+                                                 time.time(),
+                                                 self.validRings)
+            self.assertIn(ringname, self.validRings)
+            self.assertEqual(ringname, 'moat')
+            db.commit()
+
+        with Storage.getDB() as db:
+            ringname = db.getBridgeDistributor(bridge, self.validRings)
+            self.assertEqual(ringname, 'moat')
+
+    def test_getBridgeDistributor_unrecognised(self):
+        bridge = self.fakeBridges[0]
+        Storage.initializeDBLock()
+        with Storage.getDB() as db:
+            ringname = db.insertBridgeAndGetRing(bridge, 'godzilla',
+                                                 time.time(),
+                                                 self.validRings)
+            self.assertIn(ringname, self.validRings)
+            self.assertEqual(ringname, "unallocated")
+            db.commit()
+
+        with Storage.getDB() as db:
+            ringname = db.getBridgeDistributor(bridge, self.validRings)
+            self.assertEqual(ringname, "unallocated")





More information about the tor-commits mailing list