mitmproxy/test/test_tcp.py

179 lines
4.7 KiB
Python
Raw Normal View History

2012-06-18 21:42:32 +00:00
import cStringIO, threading, Queue
from netlib import tcp, certutils
2012-06-18 21:42:32 +00:00
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):
2012-07-04 21:37:43 +00:00
cls.q = Queue.Queue()
s = cls.makeserver()
cls.port = s.port
cls.server = ServerThread(s)
2012-06-18 21:42:32 +00:00
cls.server.start()
@classmethod
def teardownAll(cls):
cls.server.shutdown()
2012-06-25 21:50:42 +00:00
class SNIHandler(tcp.BaseHandler):
sni = None
def handle_sni(self, connection):
self.sni = connection.get_servername()
def handle(self):
self.wfile.write(self.sni)
self.wfile.flush()
class EchoHandler(tcp.BaseHandler):
2012-06-25 21:50:42 +00:00
sni = None
def handle_sni(self, connection):
self.sni = connection.get_servername()
2012-06-18 21:42:32 +00:00
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 DisconnectHandler(tcp.BaseHandler):
def handle(self):
self.finish()
2012-06-18 21:42:32 +00:00
class TServer(tcp.TCPServer):
def __init__(self, addr, ssl, q, handler, v3_only=False):
2012-06-18 21:42:32 +00:00
tcp.TCPServer.__init__(self, addr)
self.ssl, self.q = ssl, q
self.v3_only = v3_only
self.handler = handler
2012-06-18 21:42:32 +00:00
def handle_connection(self, request, client_address):
h = self.handler(request, client_address, self)
if self.ssl:
if self.v3_only:
method = tcp.SSLv3_METHOD
options = tcp.OP_NO_SSLv2|tcp.OP_NO_TLSv1
else:
method = tcp.SSLv23_METHOD
options = None
h.convert_to_ssl(
tutils.test_data.path("data/server.crt"),
tutils.test_data.path("data/server.key"),
method = method,
options = options,
)
h.handle()
h.finish()
2012-06-18 21:42:32 +00:00
def handle_error(self, request, client_address):
s = cStringIO.StringIO()
tcp.TCPServer.handle_error(self, request, client_address, s)
self.q.put(s.getvalue())
class TestServer(ServerTestBase):
@classmethod
def makeserver(cls):
2012-07-04 21:37:43 +00:00
return TServer(("127.0.0.1", 0), False, cls.q, EchoHandler)
2012-06-18 21:42:32 +00:00
def test_echo(self):
testval = "echo!\n"
c = tcp.TCPClient("127.0.0.1", self.port)
c.connect()
2012-06-18 21:42:32 +00:00
c.wfile.write(testval)
c.wfile.flush()
assert c.rfile.readline() == testval
class TestServerSSL(ServerTestBase):
@classmethod
def makeserver(cls):
2012-07-04 21:37:43 +00:00
return TServer(("127.0.0.1", 0), True, cls.q, EchoHandler)
def test_echo(self):
c = tcp.TCPClient("127.0.0.1", self.port)
c.connect()
2012-06-25 21:50:42 +00:00
c.convert_to_ssl(sni="foo.com")
testval = "echo!\n"
2012-06-18 21:42:32 +00:00
c.wfile.write(testval)
c.wfile.flush()
assert c.rfile.readline() == testval
2012-06-18 21:42:32 +00:00
def test_get_remote_cert(self):
assert certutils.get_remote_cert("127.0.0.1", self.port, None).digest("sha1")
2012-06-18 21:42:32 +00:00
class TestSSLv3Only(ServerTestBase):
@classmethod
def makeserver(cls):
2012-07-04 21:37:43 +00:00
return TServer(("127.0.0.1", 0), True, cls.q, EchoHandler, True)
def test_failure(self):
c = tcp.TCPClient("127.0.0.1", self.port)
c.connect()
tutils.raises(tcp.NetLibError, c.convert_to_ssl, sni="foo.com", method=tcp.TLSv1_METHOD)
2012-06-25 21:50:42 +00:00
class TestSNI(ServerTestBase):
@classmethod
def makeserver(cls):
2012-07-04 21:37:43 +00:00
return TServer(("127.0.0.1", 0), True, cls.q, SNIHandler)
2012-06-25 21:50:42 +00:00
def test_echo(self):
c = tcp.TCPClient("127.0.0.1", self.port)
c.connect()
c.convert_to_ssl(sni="foo.com")
assert c.rfile.readline() == "foo.com"
class TestSSLDisconnect(ServerTestBase):
@classmethod
def makeserver(cls):
2012-07-04 21:37:43 +00:00
return TServer(("127.0.0.1", 0), True, cls.q, DisconnectHandler)
def test_echo(self):
c = tcp.TCPClient("127.0.0.1", self.port)
c.connect()
c.convert_to_ssl()
# Excercise SSL.ZeroReturnError
c.rfile.read(10)
2012-06-18 21:42:32 +00:00
class TestTCPClient:
def test_conerr(self):
c = tcp.TCPClient("127.0.0.1", 0)
tutils.raises(tcp.NetLibError, c.connect)
2012-06-18 21:42:32 +00:00
class TestFileLike:
def test_wrap(self):
s = cStringIO.StringIO("foobar\nfoobar")
s = tcp.FileLike(s)
s.flush()
assert s.readline() == "foobar\n"
assert s.readline() == "foobar"
# Test __getattr__
assert s.isatty
def test_limit(self):
s = cStringIO.StringIO("foobar\nfoobar")
s = tcp.FileLike(s)
assert s.readline(3) == "foo"