2012-06-29 22:51:13 +00:00
|
|
|
import json, cStringIO
|
2012-06-26 05:28:07 +00:00
|
|
|
from libpathod import pathoc, test, version
|
|
|
|
import tutils
|
|
|
|
|
|
|
|
|
|
|
|
class TestDaemon:
|
|
|
|
@classmethod
|
|
|
|
def setUpAll(self):
|
|
|
|
self.d = test.Daemon(
|
|
|
|
staticdir=tutils.test_data.path("data"),
|
|
|
|
anchors=[("/anchor/.*", "202")]
|
|
|
|
)
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def tearDownAll(self):
|
|
|
|
self.d.shutdown()
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.d.clear_log()
|
|
|
|
|
|
|
|
def test_info(self):
|
|
|
|
c = pathoc.Pathoc("127.0.0.1", self.d.port)
|
|
|
|
c.connect()
|
|
|
|
_, _, _, _, content = c.request("get:/api/info")
|
|
|
|
assert tuple(json.loads(content)["version"]) == version.IVERSION
|
|
|
|
|
2012-07-23 05:42:44 +00:00
|
|
|
def test_timeout(self):
|
|
|
|
c = pathoc.Pathoc("127.0.0.1", self.d.port)
|
|
|
|
c.connect()
|
|
|
|
c.settimeout(0.01)
|
|
|
|
|
|
|
|
s = cStringIO.StringIO()
|
|
|
|
c.print_requests(
|
2012-09-25 22:12:30 +00:00
|
|
|
["get:'/p/200:p0,10'"], True, True, True, True, s
|
2012-07-23 05:42:44 +00:00
|
|
|
)
|
|
|
|
assert "Timeout" in s.getvalue()
|
|
|
|
|
2012-09-25 22:12:30 +00:00
|
|
|
def tval(self, requests, showreq=False, showresp=False, explain=False, hexdump=False):
|
2012-06-29 22:51:13 +00:00
|
|
|
c = pathoc.Pathoc("127.0.0.1", self.d.port)
|
|
|
|
c.connect()
|
|
|
|
s = cStringIO.StringIO()
|
2012-09-25 22:12:30 +00:00
|
|
|
c.print_requests(
|
|
|
|
requests,
|
|
|
|
showreq = showreq,
|
|
|
|
showresp = showresp,
|
|
|
|
explain = explain,
|
|
|
|
hexdump = hexdump,
|
|
|
|
fp = s
|
|
|
|
)
|
2012-06-29 22:51:13 +00:00
|
|
|
return s.getvalue()
|
|
|
|
|
2012-09-25 22:38:47 +00:00
|
|
|
def test_showresp(self):
|
2012-07-21 08:20:37 +00:00
|
|
|
reqs = [ "get:/api/info:p0,0", "get:/api/info:p0,0" ]
|
2012-09-25 22:12:30 +00:00
|
|
|
assert self.tval(reqs).count("200") == 2
|
|
|
|
assert self.tval(reqs, showresp=True).count("Date") == 2
|
2012-06-29 22:51:13 +00:00
|
|
|
|
2012-09-25 22:38:47 +00:00
|
|
|
def test_showreq(self):
|
|
|
|
reqs = [ "get:/api/info:p0,0", "get:/api/info:p0,0" ]
|
|
|
|
assert self.tval(reqs, showreq=True).count("unprintables escaped") == 2
|
|
|
|
assert self.tval(reqs, showreq=True, hexdump=True).count("hex dump") == 2
|
|
|
|
|
2012-06-29 22:51:13 +00:00
|
|
|
def test_parse_err(self):
|
|
|
|
assert "Error parsing" in self.tval(["foo"])
|
|
|
|
|
|
|
|
def test_conn_err(self):
|
|
|
|
assert "Invalid server response" in self.tval(["get:'/p/200:d2'"])
|
2012-07-22 11:37:46 +00:00
|
|
|
|
2012-09-25 22:12:30 +00:00
|
|
|
def test_explain(self):
|
|
|
|
reqs = [ "get:/api/info:ir,'x'"]
|
|
|
|
assert "inject" in self.tval(reqs, explain=True)
|
|
|
|
|
2012-07-22 11:37:46 +00:00
|
|
|
def test_fileread(self):
|
|
|
|
d = tutils.test_data.path("data/request")
|
2012-09-25 22:12:30 +00:00
|
|
|
assert "foo" in self.tval(["+%s"%d], explain=True)
|
2012-07-22 11:37:46 +00:00
|
|
|
assert "File" in self.tval(["+/nonexistent"])
|
2012-07-30 01:52:40 +00:00
|
|
|
|