2012-06-07 05:02:17 +00:00
|
|
|
import time, logging
|
2012-06-06 23:23:23 +00:00
|
|
|
import requests
|
2012-06-07 05:02:17 +00:00
|
|
|
from libpathod import test, version, utils
|
2012-06-09 03:08:51 +00:00
|
|
|
import tutils
|
2012-06-06 23:23:23 +00:00
|
|
|
|
2012-06-07 05:02:17 +00:00
|
|
|
logging.disable(logging.CRITICAL)
|
2012-06-06 23:23:23 +00:00
|
|
|
|
2012-06-09 03:08:51 +00:00
|
|
|
class TestDaemonManual:
|
2012-06-21 03:39:40 +00:00
|
|
|
def test_simple(self):
|
2012-06-06 23:23:23 +00:00
|
|
|
d = test.Daemon()
|
|
|
|
rsp = requests.get("http://localhost:%s/p/202"%d.port)
|
|
|
|
assert rsp.ok
|
|
|
|
assert rsp.status_code == 202
|
|
|
|
d.shutdown()
|
2012-06-09 03:08:51 +00:00
|
|
|
tutils.raises(requests.ConnectionError, requests.get, "http://localhost:%s/p/202"%d.port)
|
2012-06-07 05:02:17 +00:00
|
|
|
|
|
|
|
def test_startstop_ssl(self):
|
|
|
|
d = test.Daemon(ssl=True)
|
|
|
|
rsp = requests.get("https://localhost:%s/p/202"%d.port, verify=False)
|
|
|
|
assert rsp.ok
|
|
|
|
assert rsp.status_code == 202
|
|
|
|
d.shutdown()
|
2012-06-09 03:08:51 +00:00
|
|
|
tutils.raises(requests.ConnectionError, requests.get, "http://localhost:%s/p/202"%d.port)
|
2012-06-07 05:02:17 +00:00
|
|
|
|
|
|
|
def test_startstop_ssl_explicit(self):
|
|
|
|
ssloptions = dict(
|
|
|
|
keyfile = utils.data.path("resources/server.key"),
|
|
|
|
certfile = utils.data.path("resources/server.crt"),
|
|
|
|
)
|
|
|
|
d = test.Daemon(ssl=ssloptions)
|
|
|
|
rsp = requests.get("https://localhost:%s/p/202"%d.port, verify=False)
|
|
|
|
assert rsp.ok
|
|
|
|
assert rsp.status_code == 202
|
|
|
|
d.shutdown()
|
2012-06-09 03:08:51 +00:00
|
|
|
tutils.raises(requests.ConnectionError, requests.get, "http://localhost:%s/p/202"%d.port)
|
2012-06-06 23:23:23 +00:00
|
|
|
|
|
|
|
|
2012-06-09 03:08:51 +00:00
|
|
|
class TestDaemon:
|
|
|
|
@classmethod
|
2012-06-06 23:39:37 +00:00
|
|
|
def setUpAll(self):
|
2012-06-24 04:20:50 +00:00
|
|
|
self.d = test.Daemon(
|
|
|
|
staticdir=tutils.test_data.path("data"),
|
|
|
|
anchors=[("/anchor/.*", "202")]
|
|
|
|
)
|
2012-06-06 23:39:37 +00:00
|
|
|
|
2012-06-09 03:08:51 +00:00
|
|
|
@classmethod
|
2012-06-06 23:39:37 +00:00
|
|
|
def tearDownAll(self):
|
|
|
|
self.d.shutdown()
|
|
|
|
|
2012-06-24 03:07:45 +00:00
|
|
|
def setUp(self):
|
|
|
|
self.d.clear_log()
|
|
|
|
|
2012-06-24 04:20:50 +00:00
|
|
|
def getpath(self, path):
|
|
|
|
return requests.get("http://localhost:%s/%s"%(self.d.port, path))
|
|
|
|
|
2012-06-24 03:07:45 +00:00
|
|
|
def get(self, spec):
|
|
|
|
return requests.get("http://localhost:%s/p/%s"%(self.d.port, spec))
|
|
|
|
|
2012-06-06 23:39:37 +00:00
|
|
|
def test_info(self):
|
|
|
|
assert tuple(self.d.info()["version"]) == version.IVERSION
|
2012-06-21 03:39:40 +00:00
|
|
|
|
|
|
|
def test_logs(self):
|
2012-06-24 03:07:45 +00:00
|
|
|
rsp = self.get("202")
|
2012-06-21 03:39:40 +00:00
|
|
|
assert len(self.d.log()) == 1
|
|
|
|
assert self.d.clear_log()
|
|
|
|
assert len(self.d.log()) == 0
|
|
|
|
|
2012-06-24 03:07:45 +00:00
|
|
|
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
|
|
|
|
|
2012-06-24 03:12:31 +00:00
|
|
|
def test_static(self):
|
|
|
|
rsp = self.get("200:b<file")
|
|
|
|
assert rsp.status_code == 200
|
|
|
|
assert rsp.content.strip() == "testfile"
|
|
|
|
|
2012-06-24 04:20:50 +00:00
|
|
|
def test_anchor(self):
|
|
|
|
rsp = self.getpath("anchor/foo")
|
|
|
|
assert rsp.status_code == 202
|