aboutsummaryrefslogtreecommitdiffstats
path: root/test/test_tcp.py
diff options
context:
space:
mode:
authorMaximilian Hils <git@maximilianhils.com>2016-02-01 20:10:18 +0100
committerMaximilian Hils <git@maximilianhils.com>2016-02-01 20:10:18 +0100
commita3af0ce71d5b4368f1d9de8d17ff5e20086edcc4 (patch)
tree3cd42d908e898840ec434536f6a32cb97f72790c /test/test_tcp.py
parentbda49dd178fee1361f3585bd7efad67883298e5a (diff)
downloadmitmproxy-a3af0ce71d5b4368f1d9de8d17ff5e20086edcc4.tar.gz
mitmproxy-a3af0ce71d5b4368f1d9de8d17ff5e20086edcc4.tar.bz2
mitmproxy-a3af0ce71d5b4368f1d9de8d17ff5e20086edcc4.zip
tests++
Diffstat (limited to 'test/test_tcp.py')
-rw-r--r--test/test_tcp.py27
1 files changed, 23 insertions, 4 deletions
diff --git a/test/test_tcp.py b/test/test_tcp.py
index 20a295dd..2b091ef0 100644
--- a/test/test_tcp.py
+++ b/test/test_tcp.py
@@ -12,7 +12,7 @@ import OpenSSL
from netlib import tcp, certutils, tutils, tservers
from netlib.exceptions import InvalidCertificateException, TcpReadIncomplete, TlsException, \
- TcpTimeout, TcpDisconnect, TcpException
+ TcpTimeout, TcpDisconnect, TcpException, NetlibException
class EchoHandler(tcp.BaseHandler):
@@ -716,15 +716,34 @@ class TestFileLike:
class TestPeek(tservers.ServerTestBase):
handler = EchoHandler
+ def _connect(self, c):
+ c.connect()
+
def test_peek(self):
testval = b"peek!\n"
c = tcp.TCPClient(("127.0.0.1", self.port))
- c.connect()
+ self._connect(c)
c.wfile.write(testval)
c.wfile.flush()
- assert c.rfile.peek(4) == b"peek"[:4]
- assert c.rfile.peek(6) == testval
+ assert c.rfile.peek(4) == b"peek"
+ assert c.rfile.peek(6) == b"peek!\n"
+ assert c.rfile.readline() == testval
+
+ c.close()
+ with tutils.raises(NetlibException):
+ if c.rfile.peek(1) == b"":
+ # Workaround for Python 2 on Unix:
+ # Peeking a closed connection does not raise an exception here.
+ raise NetlibException()
+
+
+class TestPeekSSL(TestPeek):
+ ssl = True
+
+ def _connect(self, c):
+ c.connect()
+ c.convert_to_ssl()
class TestAddress: