mitmproxy/test/tutils.py

129 lines
3.4 KiB
Python
Raw Normal View History

2014-10-24 01:01:34 +00:00
import tempfile
import os
import re
2014-10-24 01:01:34 +00:00
import shutil
2012-06-09 03:08:51 +00:00
from contextlib import contextmanager
from libpathod import utils, test, pathoc, pathod, language
import requests
class DaemonTests:
noweb = False
noapi = False
nohang = False
ssl = False
timeout = None
hexdump = False
ssloptions = None
2014-10-24 01:01:34 +00:00
@classmethod
def setUpAll(self):
opts = self.ssloptions or {}
self.confdir = tempfile.mkdtemp()
opts["confdir"] = self.confdir
so = pathod.SSLOptions(**opts)
self.d = test.Daemon(
staticdir=test_data.path("data"),
anchors=[
(re.compile("/anchor/.*"), language.parse_response("202:da"))
],
ssl = self.ssl,
ssloptions = so,
sizelimit=1*1024*1024,
noweb = self.noweb,
noapi = self.noapi,
nohang = self.nohang,
timeout = self.timeout,
hexdump = self.hexdump,
logreq = True,
logresp = True,
explain = True
)
@classmethod
def tearDownAll(self):
self.d.shutdown()
shutil.rmtree(self.confdir)
def setUp(self):
if not (self.noweb or self.noapi):
self.d.clear_log()
2012-07-23 04:28:34 +00:00
def getpath(self, path, params=None):
scheme = "https" if self.ssl else "http"
2012-07-23 04:28:34 +00:00
return requests.get(
2014-10-24 01:01:34 +00:00
"%s://localhost:%s/%s"%(
scheme,
self.d.port,
path
),
verify=False,
params=params
2012-07-23 04:28:34 +00:00
)
def get(self, spec):
return requests.get(self.d.p(spec), verify=False)
def pathoc(self, spec, timeout=None, connect_to=None, ssl=None):
if ssl is None:
ssl = self.ssl
c = pathoc.Pathoc(("localhost", self.d.port), ssl=ssl)
c.connect(connect_to)
if timeout:
c.settimeout(timeout)
return c.request(spec)
2012-06-09 03:08:51 +00:00
@contextmanager
def tmpdir(*args, **kwargs):
orig_workdir = os.getcwd()
temp_workdir = tempfile.mkdtemp(*args, **kwargs)
os.chdir(temp_workdir)
yield temp_workdir
os.chdir(orig_workdir)
shutil.rmtree(temp_workdir)
def raises(exc, obj, *args, **kwargs):
"""
Assert that a callable raises a specified exception.
:exc An exception class or a string. If a class, assert that an
exception of this type is raised. If a string, assert that the string
occurs in the string representation of the exception, based on a
case-insenstivie match.
:obj A callable object.
:args Arguments to be passsed to the callable.
:kwargs Arguments to be passed to the callable.
"""
try:
apply(obj, args, kwargs)
except Exception, v:
if isinstance(exc, basestring):
if exc.lower() in str(v).lower():
return
else:
raise AssertionError(
"Expected %s, but caught %s"%(
repr(str(exc)), v
)
)
else:
if isinstance(v, exc):
return
else:
raise AssertionError(
"Expected %s, but caught %s %s"%(
exc.__name__, v.__class__.__name__, str(v)
)
)
raise AssertionError("No exception raised.")
test_data = utils.Data(__name__)