[tor-commits] [bridgedb/master] Remove Bridges.getDescriptorDigests().

isis at torproject.org isis at torproject.org
Sat Mar 21 02:03:00 UTC 2015


commit 016815deee25cfb27e474bb8f5be24af68ce0058
Author: Isis Lovecruft <isis at torproject.org>
Date:   Wed Feb 11 01:22:33 2015 +0000

    Remove Bridges.getDescriptorDigests().
    
    The functionality for checking the server-descriptor digest is now in
    bridgedb.bridges.Bridge.updateFromServerDescriptor(), which calls
    bridgedb.bridges.Bridge._checkServerDescriptor(). The digests are
    retrieved per-descriptor, during
    bridgedb.bridges.updateFromNetworkStatus().
    
     * REMOVE bridgedb.Bridges.getDescriptorDigests() function.
---
 lib/bridgedb/Bridges.py           |   34 ----------------------------------
 lib/bridgedb/test/test_bridges.py |   22 ----------------------
 2 files changed, 56 deletions(-)

diff --git a/lib/bridgedb/Bridges.py b/lib/bridgedb/Bridges.py
index 9e7c292..a8b0a4f 100644
--- a/lib/bridgedb/Bridges.py
+++ b/lib/bridgedb/Bridges.py
@@ -42,40 +42,6 @@ DIGEST_LEN = 20
 PORTSPEC_LEN = 16
 
 
-def getDescriptorDigests(desc):
-    """Return the SHA-1 hash hexdigests of all descriptor descs
-
-    :param File desc: A string containing the contents of one
-                      or more bridge descriptors concatenated
-                      together.
-    :returns: A dict indexed by the SHA-1 hexdigest of the bridge
-              descriptor, equivalent to that which was published
-              on the 'r' line of the networkstatus for this bridge.
-              The value is the bridge's extra-info document digest,
-              or None, if not provided.
-    """
-    if not desc: return None
-
-    descriptors = {}
-    sha1hash = hashlib.sha1()
-    ei_digest = None
-
-    for line in desc:
-        if line != '-----BEGIN SIGNATURE-----\n':
-            sha1hash.update(line)
-            if line.startswith('extra-info-digest'):
-                parts = line.split()
-                if len(parts) == 2:
-                    ei_digest = parts[1].lower()
-        else:
-            digest = sha1hash.hexdigest().lower()
-            descriptors[digest] = ei_digest
-            while line != '-----END SIGNATURE-----\n':
-                line = next(desc)
-            sha1hash = hashlib.sha1()
-            ei_digest = None
-    return descriptors
-
 def getExtraInfoDigests(doc):
     """Return the SHA-1 hash hexdigests of all extra-info documents
 
diff --git a/lib/bridgedb/test/test_bridges.py b/lib/bridgedb/test/test_bridges.py
index c481578..aff6e65 100644
--- a/lib/bridgedb/test/test_bridges.py
+++ b/lib/bridgedb/test/test_bridges.py
@@ -134,7 +134,6 @@ class BridgeIntegrationTests(unittest.TestCase):
     test_getConfigLine_vanilla_withoutFingerprint   test_integration_getConfigLine_vanilla_withoutFingerprint
     test_getConfigLine_vanilla_withFingerprint      test_integration_getConfigLine_vanilla_withFingerprint
     test_getConfigLine_scramblesuit_withFingeprint  test_integration_getConfigLine_scramblesuit_withFingerprint
-    test_getDescriptorDigests                       test_integration_getDescriptorDigests
     test_getExtraInfoDigests                        test_integration_getExtraInfoDigests
     test_splitterBridgeInsertion                    test_integration_splitterBridgeInsertion
     ==============================================  ========================
@@ -287,27 +286,6 @@ class BridgeIntegrationTests(unittest.TestCase):
                          % (self.fingerprint, ptArgsList),
                          bridgeLine)
 
-    def test_integration_getDescriptorDigests(self):
-        raise unittest.SkipTest(
-            ("The functions getDescriptorDigests() and getExtraInfoDigests() "
-             "have not been refactored into the new bridgedb.bridges module "
-             "because it's not clear yet if they're necessary. Skip these "
-             "tests for now."))
-
-        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(io.StringIO(test))
-        self.failUnlessIn(digest, digests)
-        self.failUnlessEqual(ei_digest, digests[digest])
-
     def test_integration_getExtraInfoDigests(self):
         raise unittest.SkipTest(
             ("The functions getDescriptorDigests() and getExtraInfoDigests() "





More information about the tor-commits mailing list