Start conversion to nose.

RIP pry.
This commit is contained in:
Aldo Cortesi 2012-06-09 10:57:00 +12:00
parent 7a312546f3
commit e78b48ab20
5 changed files with 156 additions and 154 deletions

1
test/.gitignore vendored Normal file
View File

@ -0,0 +1 @@
.coverage

View File

@ -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):

View File

@ -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()
]

View File

@ -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
View File

@ -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