2012-06-26 05:28:07 +00:00
|
|
|
import requests
|
2012-07-21 02:14:31 +00:00
|
|
|
from libpathod import pathod, test, version, pathoc
|
2012-07-19 23:40:37 +00:00
|
|
|
from netlib import tcp
|
2012-06-24 04:38:32 +00:00
|
|
|
import tutils
|
2012-04-28 22:56:33 +00:00
|
|
|
|
2012-06-20 22:56:30 +00:00
|
|
|
class _TestApplication:
|
2012-04-29 00:05:38 +00:00
|
|
|
def test_anchors(self):
|
2012-06-06 20:50:06 +00:00
|
|
|
a = pathod.PathodApp(staticdir=None)
|
2012-04-29 00:05:38 +00:00
|
|
|
a.add_anchor("/foo", "200")
|
2012-04-29 00:15:25 +00:00
|
|
|
assert a.get_anchors() == [("/foo", "200")]
|
|
|
|
a.add_anchor("/bar", "400")
|
|
|
|
assert a.get_anchors() == [("/bar", "400"), ("/foo", "200")]
|
|
|
|
a.remove_anchor("/bar", "400")
|
|
|
|
assert a.get_anchors() == [("/foo", "200")]
|
|
|
|
a.remove_anchor("/oink", "400")
|
|
|
|
assert a.get_anchors() == [("/foo", "200")]
|
2012-04-29 00:05:38 +00:00
|
|
|
|
2012-04-29 04:22:33 +00:00
|
|
|
|
2012-06-20 22:56:30 +00:00
|
|
|
class TestPathod:
|
|
|
|
def test_instantiation(self):
|
2012-06-24 04:20:50 +00:00
|
|
|
p = pathod.Pathod(
|
|
|
|
("127.0.0.1", 0),
|
|
|
|
anchors = [(".*", "200")]
|
|
|
|
)
|
|
|
|
assert p.anchors
|
2012-06-24 04:38:32 +00:00
|
|
|
tutils.raises("invalid regex", pathod.Pathod, ("127.0.0.1", 0), anchors=[("*", "200")])
|
|
|
|
tutils.raises("invalid page spec", pathod.Pathod, ("127.0.0.1", 0), anchors=[("foo", "bar")])
|
2012-06-21 02:29:49 +00:00
|
|
|
|
|
|
|
def test_logging(self):
|
|
|
|
p = pathod.Pathod(("127.0.0.1", 0))
|
|
|
|
assert len(p.get_log()) == 0
|
|
|
|
id = p.add_log(dict(s="foo"))
|
|
|
|
assert p.log_by_id(id)
|
|
|
|
assert len(p.get_log()) == 1
|
|
|
|
p.clear_log()
|
|
|
|
assert len(p.get_log()) == 0
|
|
|
|
|
|
|
|
for i in range(p.LOGBUF + 1):
|
|
|
|
p.add_log(dict(s="foo"))
|
|
|
|
assert len(p.get_log()) <= p.LOGBUF
|
2012-06-26 05:28:07 +00:00
|
|
|
|
|
|
|
|
2012-07-20 01:21:33 +00:00
|
|
|
class _DaemonTests:
|
2012-06-26 05:28:07 +00:00
|
|
|
@classmethod
|
|
|
|
def setUpAll(self):
|
|
|
|
self.d = test.Daemon(
|
|
|
|
staticdir=tutils.test_data.path("data"),
|
2012-07-20 01:21:33 +00:00
|
|
|
anchors=[("/anchor/.*", "202")],
|
|
|
|
ssl = self.SSL
|
2012-06-26 05:28:07 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def tearDownAll(self):
|
|
|
|
self.d.shutdown()
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
self.d.clear_log()
|
|
|
|
|
|
|
|
def getpath(self, path):
|
2012-07-20 01:21:33 +00:00
|
|
|
scheme = "https" if self.SSL else "http"
|
|
|
|
return requests.get("%s://localhost:%s/%s"%(scheme, self.d.port, path), verify=False)
|
2012-06-26 05:28:07 +00:00
|
|
|
|
|
|
|
def get(self, spec):
|
2012-07-20 01:21:33 +00:00
|
|
|
scheme = "https" if self.SSL else "http"
|
|
|
|
return requests.get("%s://localhost:%s/p/%s"%(scheme, self.d.port, spec), verify=False)
|
2012-07-19 23:40:37 +00:00
|
|
|
|
2012-07-21 08:50:41 +00:00
|
|
|
def pathoc(self, spec, timeout=None):
|
2012-07-21 02:14:31 +00:00
|
|
|
c = pathoc.Pathoc("localhost", self.d.port)
|
|
|
|
c.connect()
|
|
|
|
if self.SSL:
|
|
|
|
c.convert_to_ssl()
|
2012-07-21 08:50:41 +00:00
|
|
|
if timeout:
|
|
|
|
c.settimeout(timeout)
|
2012-07-21 02:14:31 +00:00
|
|
|
return c.request(spec)
|
|
|
|
|
|
|
|
def test_preline(self):
|
|
|
|
v = self.pathoc(r"get:'/p/200':i0,'\r\n'")
|
|
|
|
assert v[1] == 200
|
|
|
|
|
2012-06-26 05:28:07 +00:00
|
|
|
def test_info(self):
|
|
|
|
assert tuple(self.d.info()["version"]) == version.IVERSION
|
|
|
|
|
|
|
|
def test_logs(self):
|
2012-07-19 23:40:37 +00:00
|
|
|
l = len(self.d.log())
|
2012-06-26 05:28:07 +00:00
|
|
|
rsp = self.get("202")
|
2012-07-19 23:40:37 +00:00
|
|
|
assert len(self.d.log()) == l+1
|
2012-06-26 05:28:07 +00:00
|
|
|
assert self.d.clear_log()
|
|
|
|
assert len(self.d.log()) == 0
|
|
|
|
|
|
|
|
def test_disconnect(self):
|
|
|
|
rsp = self.get("202:b@100k:d200")
|
|
|
|
assert len(rsp.content) < 200
|
|
|
|
|
|
|
|
def test_parserr(self):
|
|
|
|
rsp = self.get("400:msg,b:")
|
|
|
|
assert rsp.status_code == 800
|
|
|
|
|
|
|
|
def test_static(self):
|
|
|
|
rsp = self.get("200:b<file")
|
|
|
|
assert rsp.status_code == 200
|
|
|
|
assert rsp.content.strip() == "testfile"
|
|
|
|
|
|
|
|
def test_anchor(self):
|
|
|
|
rsp = self.getpath("anchor/foo")
|
|
|
|
assert rsp.status_code == 202
|
2012-07-20 01:21:33 +00:00
|
|
|
|
|
|
|
def test_invalid_first_line(self):
|
|
|
|
c = tcp.TCPClient("localhost", self.d.port)
|
|
|
|
c.connect()
|
|
|
|
if self.SSL:
|
|
|
|
c.convert_to_ssl()
|
|
|
|
c.wfile.write("foo\n\n\n")
|
|
|
|
c.wfile.flush()
|
|
|
|
l = self.d.log()[0]
|
|
|
|
assert l["type"] == "error"
|
|
|
|
assert "foo" in l["msg"]
|
|
|
|
|
|
|
|
|
2012-07-21 08:50:41 +00:00
|
|
|
|
2012-07-20 01:21:33 +00:00
|
|
|
class TestDaemon(_DaemonTests):
|
|
|
|
SSL = False
|
|
|
|
|
|
|
|
|
|
|
|
class TestDaemonSSL(_DaemonTests):
|
|
|
|
SSL = True
|
|
|
|
def test_ssl_conn_failure(self):
|
|
|
|
c = tcp.TCPClient("localhost", self.d.port)
|
|
|
|
c.rbufsize = 0
|
|
|
|
c.wbufsize = 0
|
|
|
|
c.connect()
|
|
|
|
try:
|
|
|
|
while 1:
|
|
|
|
c.wfile.write("\r\n\r\n\r\n")
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
l = self.d.log()[0]
|
|
|
|
assert l["type"] == "error"
|
|
|
|
assert "SSL" in l["msg"]
|
|
|
|
|
|
|
|
|
|
|
|
|