aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorAldo Cortesi <aldo@nullcube.com>2016-07-13 23:26:04 +1200
committerAldo Cortesi <aldo@nullcube.com>2016-07-13 23:26:04 +1200
commit7f8fd3cdffedb537f95773110d8ef2be60666133 (patch)
tree10234846fcb292c4139ad3248ef319f140da56cd /test
parentc9a0fe6a0e6d70fa2aea1b8dc337609a9439ade1 (diff)
downloadmitmproxy-7f8fd3cdffedb537f95773110d8ef2be60666133.tar.gz
mitmproxy-7f8fd3cdffedb537f95773110d8ef2be60666133.tar.bz2
mitmproxy-7f8fd3cdffedb537f95773110d8ef2be60666133.zip
Basic outline of addons
Add addons.py, integrate with our event mechanism, and change the Master API so options is the first init argument.
Diffstat (limited to 'test')
-rw-r--r--test/mitmproxy/test_addons.py20
-rw-r--r--test/mitmproxy/test_controller.py4
-rw-r--r--test/mitmproxy/test_flow.py38
-rw-r--r--test/mitmproxy/test_script.py2
-rw-r--r--test/mitmproxy/tservers.py2
5 files changed, 43 insertions, 23 deletions
diff --git a/test/mitmproxy/test_addons.py b/test/mitmproxy/test_addons.py
new file mode 100644
index 00000000..1861d4ac
--- /dev/null
+++ b/test/mitmproxy/test_addons.py
@@ -0,0 +1,20 @@
+from __future__ import absolute_import, print_function, division
+from mitmproxy import addons
+from mitmproxy import controller
+from mitmproxy import options
+
+
+class TAddon:
+ def __init__(self, name):
+ self.name = name
+
+ def __repr__(self):
+ return "Addon(%s)" % self.name
+
+
+def test_simple():
+ m = controller.Master(options.Options())
+ a = addons.Addons(m)
+ a.add(TAddon("one"))
+ assert a.has_addon("one")
+ assert not a.has_addon("two")
diff --git a/test/mitmproxy/test_controller.py b/test/mitmproxy/test_controller.py
index 5a68e15b..6d4b8fe6 100644
--- a/test/mitmproxy/test_controller.py
+++ b/test/mitmproxy/test_controller.py
@@ -25,7 +25,7 @@ class TestMaster(object):
# Speed up test
super(DummyMaster, self).tick(0)
- m = DummyMaster()
+ m = DummyMaster(None)
assert not m.should_exit.is_set()
msg = TMsg()
msg.reply = controller.DummyReply()
@@ -34,7 +34,7 @@ class TestMaster(object):
assert m.should_exit.is_set()
def test_server_simple(self):
- m = controller.Master()
+ m = controller.Master(None)
s = DummyServer(None)
m.add_server(s)
m.start()
diff --git a/test/mitmproxy/test_flow.py b/test/mitmproxy/test_flow.py
index 74b3f599..eda01ad9 100644
--- a/test/mitmproxy/test_flow.py
+++ b/test/mitmproxy/test_flow.py
@@ -139,7 +139,7 @@ class TestClientPlaybackState:
def test_tick(self):
first = tutils.tflow()
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.start_client_playback([first, tutils.tflow()], True)
c = fm.client_playback
c.testing = True
@@ -470,7 +470,7 @@ class TestFlow(object):
def test_kill(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
f = tutils.tflow()
f.intercept(mock.Mock())
f.kill(fm)
@@ -479,7 +479,7 @@ class TestFlow(object):
def test_killall(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
f = tutils.tflow()
f.intercept(fm)
@@ -714,7 +714,7 @@ class TestSerialize:
def test_load_flows(self):
r = self._treader()
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.load_flows(r)
assert len(s.flows) == 6
@@ -725,7 +725,7 @@ class TestSerialize:
mode="reverse",
upstream_server=("https", ("use-this-domain", 80))
)
- fm = flow.FlowMaster(DummyServer(conf), s)
+ fm = flow.FlowMaster(None, DummyServer(conf), s)
fm.load_flows(r)
assert s.flows[0].request.host == "use-this-domain"
@@ -772,7 +772,7 @@ class TestFlowMaster:
def test_load_script(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.load_script(tutils.test_data.path("data/scripts/a.py"))
fm.load_script(tutils.test_data.path("data/scripts/a.py"))
@@ -788,14 +788,14 @@ class TestFlowMaster:
def test_getset_ignore(self):
p = mock.Mock()
p.config.check_ignore = HostMatcher()
- fm = flow.FlowMaster(p, flow.State())
+ fm = flow.FlowMaster(None, p, flow.State())
assert not fm.get_ignore_filter()
fm.set_ignore_filter(["^apple\.com:", ":443$"])
assert fm.get_ignore_filter()
def test_replay(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
f = tutils.tflow(resp=True)
f.request.content = None
assert "missing" in fm.replay_request(f)
@@ -808,7 +808,7 @@ class TestFlowMaster:
def test_script_reqerr(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.load_script(tutils.test_data.path("data/scripts/reqerr.py"))
f = tutils.tflow()
fm.clientconnect(f.client_conn)
@@ -816,7 +816,7 @@ class TestFlowMaster:
def test_script(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.load_script(tutils.test_data.path("data/scripts/all.py"))
f = tutils.tflow(resp=True)
@@ -852,7 +852,7 @@ class TestFlowMaster:
def test_duplicate_flow(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
f = tutils.tflow(resp=True)
fm.load_flow(f)
assert s.flow_count() == 1
@@ -863,12 +863,12 @@ class TestFlowMaster:
def test_create_flow(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
assert fm.create_request("GET", "http", "example.com", 80, "/")
def test_all(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.anticache = True
fm.anticomp = True
f = tutils.tflow(req=None)
@@ -895,7 +895,7 @@ class TestFlowMaster:
f = tutils.tflow(resp=True)
pb = [tutils.tflow(resp=True), f]
- fm = flow.FlowMaster(DummyServer(ProxyConfig()), s)
+ fm = flow.FlowMaster(None, DummyServer(ProxyConfig()), s)
assert not fm.start_server_playback(
pb,
False,
@@ -923,7 +923,7 @@ class TestFlowMaster:
f.response = HTTPResponse.wrap(netlib.tutils.tresp(content=f.request))
pb = [f]
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.refresh_server_playback = True
assert not fm.do_server_playback(tutils.tflow())
@@ -965,7 +965,7 @@ class TestFlowMaster:
f = tutils.tflow()
f.response = HTTPResponse.wrap(netlib.tutils.tresp(content=f.request))
pb = [f]
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.refresh_server_playback = True
fm.start_server_playback(
pb,
@@ -985,7 +985,7 @@ class TestFlowMaster:
def test_stickycookie(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
assert "Invalid" in fm.set_stickycookie("~h")
fm.set_stickycookie(".*")
assert fm.stickycookie_state
@@ -1007,7 +1007,7 @@ class TestFlowMaster:
def test_stickyauth(self):
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
assert "Invalid" in fm.set_stickyauth("~h")
fm.set_stickyauth(".*")
assert fm.stickyauth_state
@@ -1035,7 +1035,7 @@ class TestFlowMaster:
return list(r.stream())
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
f = tutils.tflow(resp=True)
with open(p, "ab") as tmpfile:
diff --git a/test/mitmproxy/test_script.py b/test/mitmproxy/test_script.py
index 81994780..1e8220f1 100644
--- a/test/mitmproxy/test_script.py
+++ b/test/mitmproxy/test_script.py
@@ -4,7 +4,7 @@ from . import tutils
def test_duplicate_flow():
s = flow.State()
- fm = flow.FlowMaster(None, s)
+ fm = flow.FlowMaster(None, None, s)
fm.load_script(tutils.test_data.path("data/scripts/duplicate_flow.py"))
f = tutils.tflow()
fm.request(f)
diff --git a/test/mitmproxy/tservers.py b/test/mitmproxy/tservers.py
index 0760cb53..69a50b9d 100644
--- a/test/mitmproxy/tservers.py
+++ b/test/mitmproxy/tservers.py
@@ -34,7 +34,7 @@ class TestMaster(flow.FlowMaster):
config.port = 0
s = ProxyServer(config)
state = flow.State()
- flow.FlowMaster.__init__(self, s, state)
+ flow.FlowMaster.__init__(self, None, s, state)
self.apps.add(testapp, "testapp", 80)
self.apps.add(errapp, "errapp", 80)
self.clear_log()