aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--test/mitmproxy/test_server.py24
-rw-r--r--test/mitmproxy/tservers.py20
2 files changed, 30 insertions, 14 deletions
diff --git a/test/mitmproxy/test_server.py b/test/mitmproxy/test_server.py
index 7dd738f4..74cb5ae8 100644
--- a/test/mitmproxy/test_server.py
+++ b/test/mitmproxy/test_server.py
@@ -50,10 +50,10 @@ class CommonMixin:
def test_replay(self):
assert self.pathod("304").status_code == 304
if isinstance(self, tservers.HTTPUpstreamProxyTest) and self.ssl:
- assert len(self.master.state.view) == 2
+ assert len(self.master.state.flows) == 2
else:
- assert len(self.master.state.view) == 1
- l = self.master.state.view[-1]
+ assert len(self.master.state.flows) == 1
+ l = self.master.state.flows[-1]
assert l.response.status_code == 304
l.request.path = "/p/305"
self.wait_until_not_live(l)
@@ -87,7 +87,7 @@ class CommonMixin:
# In Upstream mode with SSL, we may already have a previous CONNECT
# request.
- l = self.master.state.view[-1]
+ l = self.master.state.flows[-1]
assert l.client_conn.address
assert "host" in l.request.headers
assert l.response.status_code == 304
@@ -589,7 +589,7 @@ class TestProxy(tservers.HTTPProxyTest):
f = self.pathod("304")
assert f.status_code == 304
- f = self.master.state.view[0]
+ f = self.master.state.flows[0]
assert f.client_conn.address
assert "host" in f.request.headers
assert f.response.status_code == 304
@@ -601,7 +601,7 @@ class TestProxy(tservers.HTTPProxyTest):
f = self.pathod("304:b@1k:p50,1")
assert f.status_code == 304
- response = self.master.state.view[0].response
+ response = self.master.state.flows[0].response
# timestamp_start might fire a bit late, so we play safe and only require 300ms.
assert 0.3 <= response.timestamp_end - response.timestamp_start
@@ -620,8 +620,8 @@ class TestProxy(tservers.HTTPProxyTest):
connection.recv(50000)
connection.close()
- request, response = self.master.state.view[
- 0].request, self.master.state.view[0].response
+ request, response = self.master.state.flows[
+ 0].request, self.master.state.flows[0].response
assert response.status_code == 304 # sanity test for our low level request
# timestamp_start might fire a bit late, so we play safe and only require 300ms.
assert 0.3 <= request.timestamp_end - request.timestamp_start
@@ -647,8 +647,8 @@ class TestProxy(tservers.HTTPProxyTest):
recvd += len(connection.recv(5000))
connection.close()
- first_flow = self.master.state.view[0]
- second_flow = self.master.state.view[1]
+ first_flow = self.master.state.flows[0]
+ second_flow = self.master.state.flows[1]
assert first_flow.server_conn.timestamp_tcp_setup
assert first_flow.server_conn.timestamp_ssl_setup is None
assert second_flow.server_conn.timestamp_tcp_setup
@@ -657,7 +657,7 @@ class TestProxy(tservers.HTTPProxyTest):
def test_request_ip(self):
f = self.pathod("200:b@100")
assert f.status_code == 200
- f = self.master.state.view[0]
+ f = self.master.state.flows[0]
assert f.server_conn.address == ("127.0.0.1", self.server.port)
@@ -668,7 +668,7 @@ class TestProxySSL(tservers.HTTPProxyTest):
# tests that the ssl timestamp is present when ssl is used
f = self.pathod("304:b@10k")
assert f.status_code == 304
- first_flow = self.master.state.view[0]
+ first_flow = self.master.state.flows[0]
assert first_flow.server_conn.timestamp_ssl_setup
diff --git a/test/mitmproxy/tservers.py b/test/mitmproxy/tservers.py
index e07102e1..f9dfde30 100644
--- a/test/mitmproxy/tservers.py
+++ b/test/mitmproxy/tservers.py
@@ -7,7 +7,6 @@ import sys
from mitmproxy.proxy.config import ProxyConfig
from mitmproxy.proxy.server import ProxyServer
from mitmproxy import master
-from mitmproxy.addons import state
import pathod.test
import pathod.pathoc
from mitmproxy import controller
@@ -15,6 +14,23 @@ from mitmproxy import options
from mitmproxy import exceptions
+class TestState:
+ def __init__(self):
+ self.flows = []
+
+ def request(self, f):
+ if f not in self.flows:
+ self.flows.append(f)
+
+ def response(self, f):
+ if f not in self.flows:
+ self.flows.append(f)
+
+ # FIXME: compat with old state - remove in favor of len(state.flows)
+ def flow_count(self):
+ return len(self.flows)
+
+
class TestMaster(master.Master):
def __init__(self, opts, config):
@@ -23,7 +39,7 @@ class TestMaster(master.Master):
def clear_addons(self, addons):
self.addons.clear()
- self.state = state.State()
+ self.state = TestState()
self.addons.add(self.state)
self.addons.add(*addons)