[tor-commits] [ooni-probe/master] Write unittests for geoip web services.
art at torproject.org
art at torproject.org
Sat Mar 30 01:17:21 UTC 2013
commit e851611afd663f4c58d482d39960b2dae6ac7de6
Author: Arturo Filastò <art at fuffa.org>
Date: Fri Mar 15 15:02:04 2013 +0100
Write unittests for geoip web services.
Fix some bugs found in unittesting.
---
ooni/geoip.py | 26 ++++++++----
tests/test_geoip.py | 109 +++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 126 insertions(+), 9 deletions(-)
diff --git a/ooni/geoip.py b/ooni/geoip.py
index 0fe8a6b..55c4fa4 100644
--- a/ooni/geoip.py
+++ b/ooni/geoip.py
@@ -1,5 +1,7 @@
+import xml.etree.ElementTree as ET
import re
import os
+import random
from twisted.web import client, http_headers
from ooni.utils.net import userAgents, BodyReceiver
@@ -42,6 +44,11 @@ def IPToLocation(ipaddr):
class HTTPGeoIPLookupper(object):
url = None
+ _agent = client.Agent
+
+ def __init__(self):
+ self.agent = self._agent(reactor)
+
def _response(self, response):
content_length = response.headers.getRawHeaders('content-length')
@@ -59,16 +66,15 @@ class HTTPGeoIPLookupper(object):
pass
def failed(self, failure):
- log.err("Failed to lookup via %s" % url)
+ log.err("Failed to lookup via %s" % self.url)
log.exception(failure)
return failure
def lookup(self):
- agent = client.Agent(reactor)
headers = {}
headers['User-Agent'] = [random.choice(userAgents)]
- d = agent.request("GET", self.url, http_headers.Headers(headers))
+ d = self.agent.request("GET", self.url, http_headers.Headers(headers))
d.addCallback(self._response)
d.addErrback(self.failed)
return d
@@ -101,7 +107,7 @@ class ProbeIP(object):
strategy = None
geoIPServices = {'ubuntu': UbuntuGeoIP,
'torproject': TorProjectGeoIP,
- 'maximind': MaxMindGeoIP
+ 'maxmind': MaxMindGeoIP
}
address = None
@@ -126,20 +132,22 @@ class ProbeIP(object):
try:
yield self.askGeoIPService()
defer.returnValue(self.address)
- except Exception, e:
- print e
+ except:
log.msg("Unable to lookup the probe IP via GeoIPService")
@defer.inlineCallbacks
def askGeoIPService(self):
- for service_name, service in self.geoIPServices.items():
- s = TorProjectGeoIP()
+ # Shuffle the order in which we test the geoip services.
+ services = self.geoIPServices.items()
+ random.shuffle(services)
+ for service_name, service in services:
+ s = service()
log.msg("Looking up your IP address via %s" % service_name)
try:
self.address = yield s.lookup()
self.strategy = 'geo_ip_service-' + service_name
break
- except:
+ except Exception, e:
log.msg("Failed to lookup your IP via %s" % service_name)
def askTraceroute(self):
diff --git a/tests/test_geoip.py b/tests/test_geoip.py
new file mode 100644
index 0000000..a4ad767
--- /dev/null
+++ b/tests/test_geoip.py
@@ -0,0 +1,109 @@
+from twisted.web import server, static, resource
+from twisted.internet import reactor
+from twisted.trial import unittest
+from twisted.python.filepath import FilePath
+from twisted.protocols.policies import WrappingFactory
+
+from ooni.geoip import ProbeIP, MaxMindGeoIP, TorProjectGeoIP
+from ooni.geoip import UbuntuGeoIP, HTTPGeoIPLookupper, IPToLocation
+
+class UbuntuGeoIPResource(resource.Resource):
+ def render(self, request):
+ return """
+ <Response>
+ <Ip>127.0.0.1</Ip>
+ <Spam>Ham</Spam>
+ </Response>
+ """
+
+class MaxMindGeoIPResource(resource.Resource):
+ def render(self, request):
+ return """
+ <span id="my-ip-address">127.0.0.1</span>
+ """
+
+class TorProjectGeoIPResource(resource.Resource):
+ def render(self, request):
+
+ return """
+ Your IP address appears to be: <b>127.0.0.1</b>
+ """
+
+class GeoIPBaseTest(unittest.TestCase):
+ services = {'ubuntu': UbuntuGeoIPResource,
+ 'maxmind': MaxMindGeoIPResource,
+ 'torproject': TorProjectGeoIPResource
+ }
+ def _listen(self, site):
+ return reactor.listenTCP(0, site, interface="127.0.0.1")
+
+ def setUp(self):
+ r = resource.Resource()
+ for name, service in self.services.items():
+ r.putChild(name, service())
+ self.site = server.Site(r, timeout=None)
+
+ self.wrapper = WrappingFactory(self.site)
+ self.port = self._listen(self.wrapper)
+ self.portno = self.port.getHost().port
+
+ def getUrl(self, service_name):
+ return "http://%s:%s/%s" % ('127.0.0.1', self.portno, service_name)
+
+ def tearDown(self):
+ return self.port.stopListening()
+
+class TestGeoIPServices(GeoIPBaseTest):
+ def test_torproject_geoip(self):
+ gip = TorProjectGeoIP()
+ gip.url = self.getUrl('torproject')
+ d = gip.lookup()
+ @d.addCallback
+ def cb(res):
+ self.assertEqual(res, '127.0.0.1')
+ return d
+
+ def test_ubuntu_geoip(self):
+ gip = UbuntuGeoIP()
+ gip.url = self.getUrl('ubuntu')
+ d = gip.lookup()
+ @d.addCallback
+ def cb(res):
+ self.assertEqual(res, '127.0.0.1')
+ return d
+
+ def test_maxmind_geoip(self):
+ gip = MaxMindGeoIP()
+ gip.url = self.getUrl('maxmind')
+ d = gip.lookup()
+ @d.addCallback
+ def cb(res):
+ self.assertEqual(res, '127.0.0.1')
+ return d
+
+class TestProbeIP(GeoIPBaseTest):
+ def setUp(self):
+ GeoIPBaseTest.setUp(self)
+
+ # Override the service addresses with those of the fake localhost
+ # resource.
+ self.probe_ip = ProbeIP()
+ for name in self.probe_ip.geoIPServices.keys():
+ self.probe_ip.geoIPServices[name].url = self.getUrl(name)
+
+ def test_ask_geoip_service(self):
+ d = self.probe_ip.askGeoIPService()
+ @d.addCallback
+ def cb(res):
+ self.assertEqual(self.probe_ip.address, '127.0.0.1')
+ return d
+
+ def test_ask_traceroute_service(self):
+ pass
+
+ def test_ask_tor(self):
+ pass
+
+class TestIPToLocation(unittest.TestCase):
+ pass
+
More information about the tor-commits
mailing list