diff options
author | Aldo Cortesi <aldo@nullcube.com> | 2012-06-16 16:22:51 +1200 |
---|---|---|
committer | Aldo Cortesi <aldo@nullcube.com> | 2012-06-16 16:22:51 +1200 |
commit | d5a0099f4953f644bac24783d13042e3e8991e72 (patch) | |
tree | 4f745941384f4a0eeb8a10ad630808575bb5e8a1 /test | |
parent | 18a03c063e4c0f8023c5ae53fdceac6684ab7bff (diff) | |
download | mitmproxy-d5a0099f4953f644bac24783d13042e3e8991e72.tar.gz mitmproxy-d5a0099f4953f644bac24783d13042e3e8991e72.tar.bz2 mitmproxy-d5a0099f4953f644bac24783d13042e3e8991e72.zip |
Test suite and refactoring for netlib.
Diffstat (limited to 'test')
-rw-r--r-- | test/test_netlib.py | 82 |
1 files changed, 81 insertions, 1 deletions
diff --git a/test/test_netlib.py b/test/test_netlib.py index 2b76c9cf..12aa2acc 100644 --- a/test/test_netlib.py +++ b/test/test_netlib.py @@ -1,5 +1,81 @@ -import cStringIO +import cStringIO, threading, Queue from libmproxy import netlib +import tutils + +class ServerThread(threading.Thread): + def __init__(self, server): + self.server = server + threading.Thread.__init__(self) + + def run(self): + self.server.serve_forever() + + def shutdown(self): + self.server.shutdown() + + +class ServerTestBase: + @classmethod + def setupAll(cls): + cls.server = ServerThread(cls.makeserver()) + cls.server.start() + + @classmethod + def teardownAll(cls): + cls.server.shutdown() + + +class THandler(netlib.BaseHandler): + def handle(self): + v = self.rfile.readline() + if v.startswith("echo"): + self.wfile.write(v) + elif v.startswith("error"): + raise ValueError("Testing an error.") + self.wfile.flush() + + +class TServer(netlib.TCPServer): + def __init__(self, addr, q): + netlib.TCPServer.__init__(self, addr) + self.q = q + + def handle_connection(self, request, client_address): + THandler(request, client_address, self) + + def handle_error(self, request, client_address): + s = cStringIO.StringIO() + netlib.TCPServer.handle_error(self, request, client_address, s) + self.q.put(s.getvalue()) + + +class TestServer(ServerTestBase): + @classmethod + def makeserver(cls): + cls.q = Queue.Queue() + s = TServer(("127.0.0.1", 0), cls.q) + cls.port = s.port + return s + + def test_echo(self): + testval = "echo!\n" + c = netlib.TCPClient(False, "127.0.0.1", self.port, None) + c.wfile.write(testval) + c.wfile.flush() + assert c.rfile.readline() == testval + + def test_error(self): + testval = "error!\n" + c = netlib.TCPClient(False, "127.0.0.1", self.port, None) + c.wfile.write(testval) + c.wfile.flush() + assert "Testing an error" in self.q.get() + + + +class TestTCPClient: + def test_conerr(self): + tutils.raises(netlib.NetLibError, netlib.TCPClient, False, "127.0.0.1", 0, None) class TestFileLike: @@ -12,4 +88,8 @@ class TestFileLike: # Test __getattr__ assert s.isatty + def test_limit(self): + s = cStringIO.StringIO("foobar\nfoobar") + s = netlib.FileLike(s) + assert s.readline(3) == "foo" |