[tor-commits] [bridgedb/master] Add tests for Bridge.allVanillaAddresses idempotency and reentrancy.

isis at torproject.org isis at torproject.org
Sat Jul 25 19:26:19 UTC 2015


commit f8b5300f81aca52a6b34f36201fecf58ff817628
Author: Isis Lovecruft <isis at torproject.org>
Date:   Sun May 10 22:24:32 2015 +0000

    Add tests for Bridge.allVanillaAddresses idempotency and reentrancy.
---
 lib/bridgedb/test/test_bridges.py |  113 +++++++++++++++++++++++++++++++++++++
 1 file changed, 113 insertions(+)

diff --git a/lib/bridgedb/test/test_bridges.py b/lib/bridgedb/test/test_bridges.py
index 7778b02..99fc458 100644
--- a/lib/bridgedb/test/test_bridges.py
+++ b/lib/bridgedb/test/test_bridges.py
@@ -988,6 +988,119 @@ class BridgeTests(unittest.TestCase):
                                                  bridgePrefix=True)
         self.assertEqual(bridgeline, 'Bridge [6bf3:806b:78cd::4ced:cfad:dad4]:36488')
 
+    def test_Bridge_allVanillaAddresses_idempotency_self(self):
+        """Bridge.allVanillaAddresses should be idempotent, i.e. calling
+        allVanillaAddresses should not affect the results of subsequent calls.
+        """
+        self.bridge.address = '1.1.1.1'
+        self.bridge.orPort = 443
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+
+    def test_Bridge_allVanillaAddresses_idempotency_others(self):
+        """Bridge.allVanillaAddresses should be idempotent, i.e. calling
+        allVanillaAddresses should not affect any of the Bridge's other
+        attributes (such as Bridge.orAddresses).
+        """
+        self.bridge.address = '1.1.1.1'
+        self.bridge.orPort = 443
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+
+    def test_Bridge_allVanillaAddresses_reentrancy_all(self):
+        """Bridge.allVanillaAddresses should be reentrant, i.e. updating the
+        Bridge's address, orPort, or orAddresses should update the value
+        returned by allVanillaAddresses.
+        """
+        self.bridge.address = '1.1.1.1'
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), None, 4)])
+        self.assertEqual(self.bridge.address, ipaddr.IPv4Address('1.1.1.1'))
+        self.assertEqual(self.bridge.orPort, None)
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+
+        self.bridge.orPort = 443
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertEqual(self.bridge.address, ipaddr.IPv4Address('1.1.1.1'))
+        self.assertEqual(self.bridge.orPort, 443)
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+
+        self.bridge.address = '2.2.2.2'
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('2.2.2.2'), 443, 4)])
+        self.assertEqual(self.bridge.address, ipaddr.IPv4Address('2.2.2.2'))
+        self.assertEqual(self.bridge.orPort, 443)
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+
+        self.bridge.orAddresses.append(
+            (ipaddr.IPv6Address('200::6ffb:11bb:a129'), 4443, 6))
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('2.2.2.2'), 443, 4),
+                               (ipaddr.IPv6Address('200::6ffb:11bb:a129'), 4443, 6)])
+        self.assertEqual(self.bridge.address, ipaddr.IPv4Address('2.2.2.2'))
+        self.assertEqual(self.bridge.orPort, 443)
+        self.assertItemsEqual(self.bridge.orAddresses,
+                         [(ipaddr.IPv6Address('200::6ffb:11bb:a129'), 4443, 6)])
+
+    def test_Bridge_allVanillaAddresses_reentrancy_orPort(self):
+        """Calling Bridge.allVanillaAddresses before Bridge.orPort is set
+        should return ``None`` for the port value, and after Bridge.orPort is
+        set, it should return the orPort.
+        """
+        self.bridge.address = '1.1.1.1'
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), None, 4)])
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+
+        self.bridge.orPort = 443
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+
+    def test_Bridge_allVanillaAddresses_reentrancy_address(self):
+        """Calling Bridge.allVanillaAddresses before Bridge.address is set
+        should return ``None`` for the address value, and after Bridge.address
+        is set, it should return the address.
+        """
+        self.bridge.orPort = 443
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(None, 443, 4)])
+        self.bridge.address = '1.1.1.1'
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+
+    def test_Bridge_allVanillaAddresses_reentrancy_orAddresses(self):
+        """Calling Bridge.allVanillaAddresses before Bridge.orAddresses is set
+        should return only the Bridge's address and orPort.
+        """
+        self.bridge.address = '1.1.1.1'
+        self.bridge.orPort = 443
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+        self.assertItemsEqual(self.bridge.orAddresses, [])
+        self.bridge.orAddresses.append(
+            (ipaddr.IPv4Address('2.2.2.2'), 4443, 4))
+        self.assertItemsEqual(self.bridge.orAddresses,
+                              [(ipaddr.IPv4Address('2.2.2.2'), 4443, 4)])
+        self.assertItemsEqual(self.bridge.allVanillaAddresses,
+                              [(ipaddr.IPv4Address('2.2.2.2'), 4443, 4),
+                               (ipaddr.IPv4Address('1.1.1.1'), 443, 4)])
+
     def test_Bridge_updateORAddresses_valid_and_invalid(self):
         """Bridge._updateORAddresses() called with a mixture of valid and
         invalid ORAddress tuples should only retain the valid ones.





More information about the tor-commits mailing list