[tor-commits] [bridgedb/master] Add some unit tests for Bridges module

isis at torproject.org isis at torproject.org
Fri Feb 21 21:56:57 UTC 2014


commit b528a3b1469fe93c427bfbc9363f2bc7f2433312
Author: Matthew Finkel <Matthew.Finkel at gmail.com>
Date:   Sun Feb 2 06:59:16 2014 +0000

    Add some unit tests for Bridges module
---
 lib/bridgedb/test/test_Bridges.py |  111 +++++++++++++++++++++++++++++++++++++
 1 file changed, 111 insertions(+)

diff --git a/lib/bridgedb/test/test_Bridges.py b/lib/bridgedb/test/test_Bridges.py
new file mode 100644
index 0000000..4e0b27e
--- /dev/null
+++ b/lib/bridgedb/test/test_Bridges.py
@@ -0,0 +1,111 @@
+# -*- coding: utf-8 -*-
+#
+# This file is part of BridgeDB, a Tor bridge distribution system.
+#
+# :authors: please also see AUTHORS file
+# :copyright: (c) 2007-2013, The Tor Project, Inc.
+#             (c) 2007-2013, all entities within the AUTHORS file
+# :license: 3-Clause BSD, see LICENSE for licensing information
+
+"""Unittests for the :mod:`bridgedb.EmailServer` module."""
+
+from twisted.trial import unittest
+from binascii import a2b_hex
+from bridgedb import Bridges
+import hashlib
+try:
+    from cStringIO import StringIO
+except ImportError:
+    from io import StringIO
+
+class BridgeClassTest(unittest.TestCase):
+    """Tests for :class:`bridgedb.Bridges.Bridge`."""
+
+    def setUp(self):
+        self.nickname = 'unnamed'
+        self.ip = '127.0.0.1'
+        self.orport = '9001'
+        self.fingerprint = 'a1cc8dfef1fa11af9c40af1054df9daf45250556'
+        self.id_digest = a2b_hex(self.fingerprint)
+        self.or_addresses = {}
+
+    def test_init(self):
+        try:
+            Bridges.Bridge(self.nickname, self.ip, self.orport,
+                           fingerprint=self.fingerprint)
+            Bridges.Bridge(self.nickname, self.ip, self.orport,
+                           id_digest=self.id_digest)
+        except Exception as e:
+            self.fail("Unexpected %s exception." % type(e))
+
+        self.failUnlessRaises(TypeError, Bridges.Bridge,
+                              self.nickname, self.ip, self.orport,
+                              id_digest=self.id_digest[:-1])
+
+        self.failUnlessRaises(TypeError, Bridges.Bridge,
+                              self.nickname, self.ip, self.orport,
+                              fingerprint=self.fingerprint[:-1])
+
+        self.failUnlessRaises(TypeError, Bridges.Bridge,
+                              self.nickname, self.ip, self.orport)
+
+        invalid_fingerprint = self.fingerprint[:-1] + 'q'
+        self.failUnlessRaises(TypeError, Bridges.Bridge, self.nickname,
+                              self.ip, self.orport,
+                              fingerprint=invalid_fingerprint)
+
+    def test_Bridgehelperfunctions(self):
+        bridge = Bridges.Bridge(self.nickname, self.ip, self.orport,
+                                self.fingerprint)
+        self.assertEqual(self.id_digest, bridge.getID())
+
+        testtext = 'thisisatest'
+        bridge.setDescriptorDigest(testtext)
+        self.assertEqual(bridge.desc_digest, testtext)
+        bridge.setExtraInfoDigest(testtext)
+        self.assertEqual(bridge.ei_digest, testtext)
+        bridge.setVerified()
+        self.assertTrue(bridge.isVerified())
+        self.assertTrue(bridge.verified)
+        self.assertEqual(self.id_digest, bridge.getID())
+
+        self.assertFalse(bridge.running)
+        self.assertFalse(bridge.stable)
+        bridge.setStatus(True, True)
+        self.assertTrue(bridge.running)
+        self.assertTrue(bridge.stable)
+
+#    def test_isBlocked(self):
+        
+
+    def test_getDescriptorDigests(self):
+        sha1hash = hashlib.sha1()
+        ei_digest = 'abcdefghijklmno'
+
+        test = "this is a test line\nFollowed by another\n"
+        test += "extra-info-digest %s\n" % ei_digest
+        sha1hash.update(test)
+        digest = sha1hash.hexdigest()
+        test += "-----BEGIN SIGNATURE-----\n"
+        test += "This is a test line that should be skipped\n"
+        test += "-----END SIGNATURE-----\n"
+        digests = Bridges.getDescriptorDigests(StringIO(test))
+        self.failUnlessIn(digest, digests)
+        self.failUnlessEqual(ei_digest, digests[digest])
+
+    def test_getExtraInfoDigests(self):
+        sha1hash = hashlib.sha1()
+
+        test = "Many words and line all together\n"
+        test += "extra info is nothing like weather\n"
+        test += "it's certain to come, like the key in a hum\n"
+        test += "but sometimes without a transport and rum\n"
+        content = test
+        sha1hash.update(test)
+        digest = sha1hash.hexdigest()
+        test += "-----BEGIN SIGNATURE-----\n"
+        test += "But the rum can't save the world like you\n"
+        test += "-----END SIGNATURE-----\n"
+        digests = Bridges.getExtraInfoDigests(StringIO(test))
+        self.failUnlessIn(digest, digests)
+        self.failUnlessEqual(content, digests[digest].read())





More information about the tor-commits mailing list