aboutsummaryrefslogtreecommitdiffstats
path: root/pathod/test.py
diff options
context:
space:
mode:
authorMaximilian Hils <git@maximilianhils.com>2016-02-18 13:03:40 +0100
committerMaximilian Hils <git@maximilianhils.com>2016-02-18 13:03:40 +0100
commitd33d3663ecb166461d9cb5a78a29b44ee7a8fbb7 (patch)
treefe8856f65d1dafa946150c5acbaf6e942ba3c026 /pathod/test.py
parent294774d6f0dee95b02a93307ec493b111b7f171e (diff)
downloadmitmproxy-d33d3663ecb166461d9cb5a78a29b44ee7a8fbb7.tar.gz
mitmproxy-d33d3663ecb166461d9cb5a78a29b44ee7a8fbb7.tar.bz2
mitmproxy-d33d3663ecb166461d9cb5a78a29b44ee7a8fbb7.zip
combine projects
Diffstat (limited to 'pathod/test.py')
-rw-r--r--pathod/test.py103
1 files changed, 103 insertions, 0 deletions
diff --git a/pathod/test.py b/pathod/test.py
new file mode 100644
index 00000000..33a6b763
--- /dev/null
+++ b/pathod/test.py
@@ -0,0 +1,103 @@
+import cStringIO
+import threading
+import Queue
+
+import requests
+import requests.packages.urllib3
+from . import pathod
+
+requests.packages.urllib3.disable_warnings()
+
+
+class Daemon:
+ IFACE = "127.0.0.1"
+
+ def __init__(self, ssl=None, **daemonargs):
+ self.q = Queue.Queue()
+ self.logfp = cStringIO.StringIO()
+ daemonargs["logfp"] = self.logfp
+ self.thread = _PaThread(self.IFACE, self.q, ssl, daemonargs)
+ self.thread.start()
+ self.port = self.q.get(True, 5)
+ self.urlbase = "%s://%s:%s" % (
+ "https" if ssl else "http",
+ self.IFACE,
+ self.port
+ )
+
+ def __enter__(self):
+ return self
+
+ def __exit__(self, type, value, traceback):
+ self.logfp.truncate(0)
+ self.shutdown()
+ return False
+
+ def p(self, spec):
+ """
+ Return a URL that will render the response in spec.
+ """
+ return "%s/p/%s" % (self.urlbase, spec)
+
+ def info(self):
+ """
+ Return some basic info about the remote daemon.
+ """
+ resp = requests.get("%s/api/info" % self.urlbase, verify=False)
+ return resp.json()
+
+ def text_log(self):
+ return self.logfp.getvalue()
+
+ def last_log(self):
+ """
+ Returns the last logged request, or None.
+ """
+ l = self.log()
+ if not l:
+ return None
+ return l[0]
+
+ def log(self):
+ """
+ Return the log buffer as a list of dictionaries.
+ """
+ resp = requests.get("%s/api/log" % self.urlbase, verify=False)
+ return resp.json()["log"]
+
+ def clear_log(self):
+ """
+ Clear the log.
+ """
+ self.logfp.truncate(0)
+ resp = requests.get("%s/api/clear_log" % self.urlbase, verify=False)
+ return resp.ok
+
+ def shutdown(self):
+ """
+ Shut the daemon down, return after the thread has exited.
+ """
+ self.thread.server.shutdown()
+ self.thread.join()
+
+
+class _PaThread(threading.Thread):
+
+ def __init__(self, iface, q, ssl, daemonargs):
+ threading.Thread.__init__(self)
+ self.name = "PathodThread"
+ self.iface, self.q, self.ssl = iface, q, ssl
+ self.daemonargs = daemonargs
+
+ def run(self):
+ self.server = pathod.Pathod(
+ (self.iface, 0),
+ ssl=self.ssl,
+ **self.daemonargs
+ )
+ self.name = "PathodThread (%s:%s)" % (
+ self.server.address.host,
+ self.server.address.port
+ )
+ self.q.put(self.server.address.port)
+ self.server.serve_forever()