parent
7a312546f3
commit
e78b48ab20
|
@ -0,0 +1 @@
|
||||||
|
.coverage
|
|
@ -1,6 +1,5 @@
|
||||||
import urllib, urllib2
|
import urllib, urllib2
|
||||||
import libpathod.test, requests
|
import libpathod.test, requests
|
||||||
import libpry
|
|
||||||
import tutils
|
import tutils
|
||||||
|
|
||||||
class uSanity(tutils.ProxTest):
|
class uSanity(tutils.ProxTest):
|
||||||
|
|
|
@ -1,202 +1,168 @@
|
||||||
import textwrap, re, json
|
import textwrap, re, json
|
||||||
import libpry
|
|
||||||
from libmproxy import utils
|
from libmproxy import utils
|
||||||
|
from nose.tools import assert_raises
|
||||||
|
import tutils
|
||||||
|
|
||||||
utils.CERT_SLEEP_TIME = 0
|
utils.CERT_SLEEP_TIME = 0
|
||||||
|
|
||||||
|
|
||||||
class uformat_timestamp(libpry.AutoTree):
|
def test_format_timestamp():
|
||||||
def test_simple(self):
|
assert utils.format_timestamp(utils.timestamp())
|
||||||
assert utils.format_timestamp(utils.timestamp())
|
|
||||||
|
|
||||||
|
|
||||||
class uisBin(libpry.AutoTree):
|
def test_isBin():
|
||||||
def test_simple(self):
|
assert not utils.isBin("testing\n\r")
|
||||||
assert not utils.isBin("testing\n\r")
|
assert utils.isBin("testing\x01")
|
||||||
assert utils.isBin("testing\x01")
|
assert utils.isBin("testing\x0e")
|
||||||
assert utils.isBin("testing\x0e")
|
assert utils.isBin("testing\x7f")
|
||||||
assert utils.isBin("testing\x7f")
|
|
||||||
|
|
||||||
|
|
||||||
class uisXML(libpry.AutoTree):
|
def test_isXml():
|
||||||
def test_simple(self):
|
assert not utils.isXML("foo")
|
||||||
assert not utils.isXML("foo")
|
assert utils.isXML("<foo")
|
||||||
assert utils.isXML("<foo")
|
assert utils.isXML(" \n<foo")
|
||||||
assert utils.isXML(" \n<foo")
|
|
||||||
|
|
||||||
|
|
||||||
class uhexdump(libpry.AutoTree):
|
def test_hexdump():
|
||||||
def test_simple(self):
|
assert utils.hexdump("one\0"*10)
|
||||||
assert utils.hexdump("one\0"*10)
|
|
||||||
|
|
||||||
|
|
||||||
class udel_all(libpry.AutoTree):
|
def test_del_all():
|
||||||
def test_simple(self):
|
d = dict(a=1, b=2, c=3)
|
||||||
d = dict(a=1, b=2, c=3)
|
utils.del_all(d, ["a", "x", "b"])
|
||||||
utils.del_all(d, ["a", "x", "b"])
|
assert d.keys() == ["c"]
|
||||||
assert d.keys() == ["c"]
|
|
||||||
|
|
||||||
|
|
||||||
class uclean_hanging_newline(libpry.AutoTree):
|
def test_clean_hanging_newline():
|
||||||
def test_simple(self):
|
s = "foo\n"
|
||||||
s = "foo\n"
|
assert utils.clean_hanging_newline(s) == "foo"
|
||||||
assert utils.clean_hanging_newline(s) == "foo"
|
assert utils.clean_hanging_newline("foo") == "foo"
|
||||||
assert utils.clean_hanging_newline("foo") == "foo"
|
|
||||||
|
|
||||||
|
|
||||||
class upretty_size(libpry.AutoTree):
|
def test_pretty_size():
|
||||||
def test_simple(self):
|
assert utils.pretty_size(100) == "100B"
|
||||||
assert utils.pretty_size(100) == "100B"
|
assert utils.pretty_size(1024) == "1kB"
|
||||||
assert utils.pretty_size(1024) == "1kB"
|
assert utils.pretty_size(1024 + (1024/2.0)) == "1.5kB"
|
||||||
assert utils.pretty_size(1024 + (1024/2.0)) == "1.5kB"
|
assert utils.pretty_size(1024*1024) == "1M"
|
||||||
assert utils.pretty_size(1024*1024) == "1M"
|
|
||||||
|
|
||||||
|
|
||||||
class uData(libpry.AutoTree):
|
def test_pkg_data():
|
||||||
def test_nonexistent(self):
|
assert utils.pkg_data.path("console")
|
||||||
assert utils.pkg_data.path("console")
|
tutils.raises("does not exist", utils.pkg_data.path, "nonexistent")
|
||||||
libpry.raises("does not exist", utils.pkg_data.path, "nonexistent")
|
|
||||||
|
|
||||||
|
|
||||||
class upretty_json(libpry.AutoTree):
|
def test_pretty_json():
|
||||||
def test_one(self):
|
s = json.dumps({"foo": 1})
|
||||||
s = json.dumps({"foo": 1})
|
assert utils.pretty_json(s)
|
||||||
assert utils.pretty_json(s)
|
assert not utils.pretty_json("moo")
|
||||||
assert not utils.pretty_json("moo")
|
|
||||||
|
|
||||||
|
|
||||||
class u_urldecode(libpry.AutoTree):
|
def test_urldecode():
|
||||||
def test_one(self):
|
s = "one=two&three=four"
|
||||||
s = "one=two&three=four"
|
assert len(utils.urldecode(s)) == 2
|
||||||
assert len(utils.urldecode(s)) == 2
|
|
||||||
|
|
||||||
|
|
||||||
class uLRUCache(libpry.AutoTree):
|
def test_LRUCache():
|
||||||
def test_one(self):
|
class Foo:
|
||||||
class Foo:
|
ran = False
|
||||||
ran = False
|
@utils.LRUCache(2)
|
||||||
@utils.LRUCache(2)
|
def one(self, x):
|
||||||
def one(self, x):
|
self.ran = True
|
||||||
self.ran = True
|
return x
|
||||||
return x
|
|
||||||
|
|
||||||
f = Foo()
|
f = Foo()
|
||||||
assert f.one(1) == 1
|
assert f.one(1) == 1
|
||||||
assert f.ran
|
assert f.ran
|
||||||
f.ran = False
|
f.ran = False
|
||||||
assert f.one(1) == 1
|
assert f.one(1) == 1
|
||||||
assert not f.ran
|
assert not f.ran
|
||||||
|
|
||||||
f.ran = False
|
f.ran = False
|
||||||
assert f.one(1) == 1
|
assert f.one(1) == 1
|
||||||
assert not f.ran
|
assert not f.ran
|
||||||
assert f.one(2) == 2
|
assert f.one(2) == 2
|
||||||
assert f.one(3) == 3
|
assert f.one(3) == 3
|
||||||
assert f.ran
|
assert f.ran
|
||||||
|
|
||||||
f.ran = False
|
f.ran = False
|
||||||
assert f.one(1) == 1
|
assert f.one(1) == 1
|
||||||
assert f.ran
|
assert f.ran
|
||||||
|
|
||||||
assert len(f._cached_one) == 2
|
assert len(f._cached_one) == 2
|
||||||
assert len(f._cachelist_one) == 2
|
assert len(f._cachelist_one) == 2
|
||||||
|
|
||||||
|
|
||||||
class u_parse_proxy_spec(libpry.AutoTree):
|
def test_parse_proxy_spec():
|
||||||
def test_simple(self):
|
assert not utils.parse_proxy_spec("")
|
||||||
assert not utils.parse_proxy_spec("")
|
assert utils.parse_proxy_spec("http://foo.com:88") == ("http", "foo.com", 88)
|
||||||
assert utils.parse_proxy_spec("http://foo.com:88") == ("http", "foo.com", 88)
|
assert utils.parse_proxy_spec("http://foo.com") == ("http", "foo.com", 80)
|
||||||
assert utils.parse_proxy_spec("http://foo.com") == ("http", "foo.com", 80)
|
assert not utils.parse_proxy_spec("foo.com")
|
||||||
assert not utils.parse_proxy_spec("foo.com")
|
assert not utils.parse_proxy_spec("http://")
|
||||||
assert not utils.parse_proxy_spec("http://")
|
|
||||||
|
|
||||||
|
|
||||||
class u_unparse_url(libpry.AutoTree):
|
def test_unparse_url():
|
||||||
def test_simple(self):
|
assert utils.unparse_url("http", "foo.com", 99, "") == "http://foo.com:99"
|
||||||
assert utils.unparse_url("http", "foo.com", 99, "") == "http://foo.com:99"
|
assert utils.unparse_url("http", "foo.com", 80, "") == "http://foo.com"
|
||||||
assert utils.unparse_url("http", "foo.com", 80, "") == "http://foo.com"
|
assert utils.unparse_url("https", "foo.com", 80, "") == "https://foo.com:80"
|
||||||
assert utils.unparse_url("https", "foo.com", 80, "") == "https://foo.com:80"
|
assert utils.unparse_url("https", "foo.com", 443, "") == "https://foo.com"
|
||||||
assert utils.unparse_url("https", "foo.com", 443, "") == "https://foo.com"
|
|
||||||
|
|
||||||
|
|
||||||
class u_parse_url(libpry.AutoTree):
|
def test_parse_url():
|
||||||
def test_simple(self):
|
assert not utils.parse_url("")
|
||||||
assert not utils.parse_url("")
|
|
||||||
|
|
||||||
u = "http://foo.com:8888/test"
|
u = "http://foo.com:8888/test"
|
||||||
s, h, po, pa = utils.parse_url(u)
|
s, h, po, pa = utils.parse_url(u)
|
||||||
assert s == "http"
|
assert s == "http"
|
||||||
assert h == "foo.com"
|
assert h == "foo.com"
|
||||||
assert po == 8888
|
assert po == 8888
|
||||||
assert pa == "/test"
|
assert pa == "/test"
|
||||||
|
|
||||||
s, h, po, pa = utils.parse_url("http://foo/bar")
|
s, h, po, pa = utils.parse_url("http://foo/bar")
|
||||||
assert s == "http"
|
assert s == "http"
|
||||||
assert h == "foo"
|
assert h == "foo"
|
||||||
assert po == 80
|
assert po == 80
|
||||||
assert pa == "/bar"
|
assert pa == "/bar"
|
||||||
|
|
||||||
s, h, po, pa = utils.parse_url("http://foo")
|
s, h, po, pa = utils.parse_url("http://foo")
|
||||||
assert pa == "/"
|
assert pa == "/"
|
||||||
|
|
||||||
s, h, po, pa = utils.parse_url("https://foo")
|
s, h, po, pa = utils.parse_url("https://foo")
|
||||||
assert po == 443
|
assert po == 443
|
||||||
|
|
||||||
assert not utils.parse_url("https://foo:bar")
|
assert not utils.parse_url("https://foo:bar")
|
||||||
assert not utils.parse_url("https://foo:")
|
assert not utils.parse_url("https://foo:")
|
||||||
|
|
||||||
|
|
||||||
class u_parse_size(libpry.AutoTree):
|
def test_parse_size():
|
||||||
def test_simple(self):
|
assert not utils.parse_size("")
|
||||||
assert not utils.parse_size("")
|
assert utils.parse_size("1") == 1
|
||||||
assert utils.parse_size("1") == 1
|
assert utils.parse_size("1k") == 1024
|
||||||
assert utils.parse_size("1k") == 1024
|
assert utils.parse_size("1m") == 1024**2
|
||||||
assert utils.parse_size("1m") == 1024**2
|
assert utils.parse_size("1g") == 1024**3
|
||||||
assert utils.parse_size("1g") == 1024**3
|
tutils.raises(ValueError, utils.parse_size, "1f")
|
||||||
libpry.raises(ValueError, utils.parse_size, "1f")
|
tutils.raises(ValueError, utils.parse_size, "ak")
|
||||||
libpry.raises(ValueError, utils.parse_size, "ak")
|
|
||||||
|
|
||||||
|
|
||||||
class u_parse_content_type(libpry.AutoTree):
|
def test_parse_content_type():
|
||||||
def test_simple(self):
|
p = utils.parse_content_type
|
||||||
p = utils.parse_content_type
|
assert p("text/html") == ("text", "html", {})
|
||||||
assert p("text/html") == ("text", "html", {})
|
assert p("text") == None
|
||||||
assert p("text") == None
|
|
||||||
|
|
||||||
v = p("text/html; charset=UTF-8")
|
v = p("text/html; charset=UTF-8")
|
||||||
assert v == ('text', 'html', {'charset': 'UTF-8'})
|
assert v == ('text', 'html', {'charset': 'UTF-8'})
|
||||||
|
|
||||||
|
|
||||||
class u_cleanBin(libpry.AutoTree):
|
def test_cleanBin():
|
||||||
def test_simple(self):
|
assert utils.cleanBin("one") == "one"
|
||||||
assert utils.cleanBin("one") == "one"
|
assert utils.cleanBin("\00ne") == ".ne"
|
||||||
assert utils.cleanBin("\00ne") == ".ne"
|
assert utils.cleanBin("\nne") == "\nne"
|
||||||
assert utils.cleanBin("\nne") == "\nne"
|
assert utils.cleanBin("\nne", True) == ".ne"
|
||||||
assert utils.cleanBin("\nne", True) == ".ne"
|
|
||||||
|
|
||||||
|
|
||||||
class u_safe_subn(libpry.AutoTree):
|
def test_safe_subn():
|
||||||
def test_simple(self):
|
assert utils.safe_subn("foo", u"bar", "\xc2foo")
|
||||||
assert utils.safe_subn("foo", u"bar", "\xc2foo")
|
|
||||||
|
|
||||||
|
|
||||||
tests = [
|
def test_urlencode():
|
||||||
u_safe_subn(),
|
assert utils.urlencode([('foo','bar')])
|
||||||
u_cleanBin(),
|
|
||||||
u_parse_content_type(),
|
|
||||||
uformat_timestamp(),
|
|
||||||
uisBin(),
|
|
||||||
uisXML(),
|
|
||||||
uhexdump(),
|
|
||||||
upretty_size(),
|
|
||||||
uData(),
|
|
||||||
upretty_json(),
|
|
||||||
u_urldecode(),
|
|
||||||
udel_all(),
|
|
||||||
uLRUCache(),
|
|
||||||
u_parse_url(),
|
|
||||||
u_parse_proxy_spec(),
|
|
||||||
u_unparse_url(),
|
|
||||||
u_parse_size(),
|
|
||||||
uclean_hanging_newline()
|
|
||||||
]
|
|
||||||
|
|
|
@ -133,3 +133,42 @@ class ProxTest(libpry.AutoTree):
|
||||||
pthread = self.findAttr("proxy")
|
pthread = self.findAttr("proxy")
|
||||||
return pthread.tmaster.log
|
return pthread.tmaster.log
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
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.")
|
||||||
|
|
3
todo
3
todo
|
@ -14,9 +14,6 @@ Targeted for 0.9:
|
||||||
|
|
||||||
|
|
||||||
Future:
|
Future:
|
||||||
- Rewrite the core to be asynchronous. I've done some research, and
|
|
||||||
although it's a bit of a bloated monster, it looks like Twisted is the way
|
|
||||||
to go.
|
|
||||||
- Add some "workspace" features to mitmproxy:
|
- Add some "workspace" features to mitmproxy:
|
||||||
- Flow comments
|
- Flow comments
|
||||||
- Copying/duplicating flows
|
- Copying/duplicating flows
|
||||||
|
|
Loading…
Reference in New Issue