commit 75f876ee89226977d358c2dfc42b931ac94f3430 Author: Damian Johnson atagar@torproject.org Date: Fri Jan 17 12:20:30 2020 -0800
Convert generators to lists
Python 3 changes several builtins to provide generators rather than lists. This is more efficient, but means we need to convert to a list to be indexable.
There will likely be more instances down the road, but fixing all the instances that are immediately evedant in the test output. This fixes...
Traceback (most recent call last): File "/home/atagar/Desktop/tor/bridgedb/bridgedb/test/test_proxy.py", line 355, in test_ProxySet_addProxies_tuple_individual_tags self.assertEquals(len(self.proxyList), len(self.proxies) + len(extraProxies)) builtins.TypeError: object of type 'zip' has no len()
Traceback (most recent call last): File "/home/atagar/Desktop/tor/bridgedb/bridgedb/test/test_parse_headers.py", line 47, in test_addNonLocalizedVariant langs = headers.parseAcceptLanguage(header) File "/home/atagar/Desktop/tor/bridgedb/bridgedb/parse/headers.py", line 70, in parseAcceptLanguage placement = langs.index(insertAfter[0]) + 1 builtins.TypeError: 'filter' object is not subscriptable
Traceback (most recent call last): File "/home/atagar/Desktop/tor/bridgedb/bridgedb/test/test_bridges.py", line 895, in setUp self._parseAllDescriptorFiles() File "/home/atagar/Desktop/tor/bridgedb/bridgedb/test/test_bridges.py", line 852, in _parseAllDescriptorFiles self._extrainfoFile).values()[0] builtins.TypeError: 'dict_values' object does not support indexing
Traceback (most recent call last): File "/home/atagar/Desktop/tor/bridgedb/bridgedb/test/test_bridges.py", line 315, in test_integration_getConfigLine_scramblesuit_withFingerprint transport='scramblesuit') File "/home/atagar/Desktop/tor/bridgedb/bridgedb/bridges.py", line 847, in getConfigLine bridgeLine = self.getBridgeLine(bridgeRequest, includeFingerprint) File "/home/atagar/Desktop/tor/bridgedb/bridgedb/bridges.py", line 1362, in getBridgeLine pt = self._getTransportForRequest(bridgeRequest) File "/home/atagar/Desktop/tor/bridgedb/bridgedb/bridges.py", line 1196, in _getTransportForRequest return transports[position % len(unblocked)] builtins.TypeError: 'filter' object is not subscriptable
Traceback (most recent call last): File "/home/atagar/Desktop/tor/bridgedb/bridgedb/test/test_Bridges.py", line 78, in test_filterDistinctSubnets_random_bridges chosen = self.ring.bridges.keys()[:3] builtins.TypeError: 'dict_keys' object is not subscriptable
Traceback (most recent call last): File "/home/atagar/Desktop/tor/bridgedb/bridgedb/test/test_Bridges.py", line 65, in test_filterDistinctSubnets chosen = self.ring.bridges.keys()[:10] builtins.TypeError: 'dict_keys' object is not subscriptable
Test results changed as follows...
before: FAILED (skips=114, failures=13, errors=191, successes=663) after: FAILED (skips=114, failures=14, errors=158, successes=695) --- bridgedb/bridges.py | 2 +- bridgedb/parse/headers.py | 4 ++-- bridgedb/test/test_Bridges.py | 4 ++-- bridgedb/test/test_bridges.py | 8 ++++---- bridgedb/test/test_proxy.py | 2 +- 5 files changed, 10 insertions(+), 10 deletions(-)
diff --git a/bridgedb/bridges.py b/bridgedb/bridges.py index ca1330b..a611c47 100644 --- a/bridgedb/bridges.py +++ b/bridgedb/bridges.py @@ -1177,7 +1177,7 @@ class Bridge(BridgeBackwardsCompatibility): # their ``methodname`` matches the requested transport: transports = filter(lambda pt: pt.methodname == desired, self.transports) # Filter again for whichever of IPv4 or IPv6 was requested: - transports = filter(lambda pt: pt.address.version == ipVersion, transports) + transports = list(filter(lambda pt: pt.address.version == ipVersion, transports))
if not transports: raise PluggableTransportUnavailable( diff --git a/bridgedb/parse/headers.py b/bridgedb/parse/headers.py index 5c3597a..fa8cbf2 100644 --- a/bridgedb/parse/headers.py +++ b/bridgedb/parse/headers.py @@ -64,8 +64,8 @@ def parseAcceptLanguage(header): for only in langsOnly: if only not in langs: # Add the fallback after the other languages like it: - insertAfter = filter(lambda x: x.startswith(only), - [x for x in langs]) + insertAfter = list(filter(lambda x: x.startswith(only), + [x for x in langs])) if insertAfter: placement = langs.index(insertAfter[0]) + 1 langs.insert(placement, only) diff --git a/bridgedb/test/test_Bridges.py b/bridgedb/test/test_Bridges.py index 5991952..19ab09c 100644 --- a/bridgedb/test/test_Bridges.py +++ b/bridgedb/test/test_Bridges.py @@ -62,7 +62,7 @@ class BridgeRingTests(unittest.TestCase): """ self.addBridgesFromSameSubnet()
- chosen = self.ring.bridges.keys()[:10] + chosen = list(self.ring.bridges.keys())[:10] bridges = self.ring.filterDistinctSubnets(chosen)
# Since they're all in the same /16, we should only get one @@ -75,7 +75,7 @@ class BridgeRingTests(unittest.TestCase): """ self.addRandomBridges()
- chosen = self.ring.bridges.keys()[:3] + chosen = list(self.ring.bridges.keys())[:3] bridges = self.ring.filterDistinctSubnets(chosen)
self.assertGreaterEqual(len(bridges), 1) diff --git a/bridgedb/test/test_bridges.py b/bridgedb/test/test_bridges.py index f2c2876..cf0ee23 100644 --- a/bridgedb/test/test_bridges.py +++ b/bridgedb/test/test_bridges.py @@ -848,10 +848,10 @@ class BridgeTests(unittest.TestCase): self._networkstatusFile)[0] self.serverdescriptor = descriptors.parseServerDescriptorsFile( self._serverDescriptorFile)[0] - self.extrainfo = descriptors.parseExtraInfoFiles( - self._extrainfoFile).values()[0] - self.extrainfoNew = descriptors.parseExtraInfoFiles( - self._extrainfoNewFile).values()[0] + self.extrainfo = list(descriptors.parseExtraInfoFiles( + self._extrainfoFile).values())[0] + self.extrainfoNew = list(descriptors.parseExtraInfoFiles( + self._extrainfoNewFile).values())[0]
def _writeNetworkstatus(self, networkstatus): with open(self._networkstatusFile, 'w') as fh: diff --git a/bridgedb/test/test_proxy.py b/bridgedb/test/test_proxy.py index 74290bc..69b2b99 100644 --- a/bridgedb/test/test_proxy.py +++ b/bridgedb/test/test_proxy.py @@ -350,7 +350,7 @@ class ProxySetUnittests(unittest.TestCase): whatever tags we want. """ tags = ['foo', 'bar', 'baz'] - extraProxies = zip(self.moarProxies, tags) + extraProxies = list(zip(self.moarProxies, tags)) self.proxyList.addProxies(extraProxies) self.assertEquals(len(self.proxyList), len(self.proxies) + len(extraProxies)) self.assertIn(extraProxies[0][0], self.proxyList)
tor-commits@lists.torproject.org