import json, cStringIO from libpathod import pathoc, test, version, pathod import tutils def test_response(): r = pathoc.Response("1.1", 200, "Message", {}, None) assert repr(r) class _TestDaemon: ssloptions = pathod.SSLOptions() @classmethod def setUpAll(self): self.d = test.Daemon( ssl=self.ssl, ssloptions=self.ssloptions, 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, ssl = self.ssl ) c.connect() r = c.request("get:/api/info") assert tuple(json.loads(r.content)["version"]) == version.IVERSION class TestDaemonSSL(_TestDaemon): ssl = True ssloptions = pathod.SSLOptions(request_client_cert=True) def test_sni(self): c = pathoc.Pathoc( "127.0.0.1", self.d.port, ssl = True, sni = "foobar.com" ) c.connect() c.request("get:/p/200") r = c.request("get:/api/log") d = json.loads(r.content) assert d["log"][0]["request"]["sni"] == "foobar.com" def test_clientcert(self): c = pathoc.Pathoc( "127.0.0.1", self.d.port, ssl = True, clientcert = tutils.test_data.path("data/clientcert/client.pem") ) c.connect() c.request("get:/p/200") r = c.request("get:/api/log") d = json.loads(r.content) assert d["log"][0]["request"]["clientcert"]["keyinfo"] class TestDaemon(_TestDaemon): ssl = False def tval(self, requests, showreq=False, showresp=False, explain=False, hexdump=False, timeout=None, ignorecodes=None, ignoretimeout=None): c = pathoc.Pathoc("127.0.0.1", self.d.port) c.connect() if timeout: c.settimeout(timeout) s = cStringIO.StringIO() for i in requests: c.print_request( i, showreq = showreq, showresp = showresp, explain = explain, hexdump = hexdump, ignorecodes = ignorecodes, ignoretimeout = ignoretimeout, fp = s ) return s.getvalue() def test_ssl_error(self): c = pathoc.Pathoc("127.0.0.1", self.d.port, ssl = True) tutils.raises("ssl handshake", c.connect) def test_ignorecodes(self): assert "200" in self.tval(["get:'/p/200:b@1'"]) assert "200" not in self.tval(["get:'/p/200:b@1'"], ignorecodes=[200]) assert "200" not in self.tval(["get:'/p/200:b@1'"], ignorecodes=[200, 201]) assert "202" in self.tval(["get:'/p/202:b@1'"], ignorecodes=[200, 201]) def test_timeout(self): assert "Timeout" in self.tval(["get:'/p/200:p0,10'"], timeout=0.01) assert "HTTP" in self.tval(["get:'/p/200:p5,10'"], showresp=True, timeout=0.01) assert not "HTTP" in self.tval(["get:'/p/200:p5,10'"], showresp=True, timeout=0.01, ignoretimeout=True) def test_showresp(self): reqs = [ "get:/api/info:p0,0", "get:/api/info:p0,0" ] assert self.tval(reqs).count("200") == 2 assert self.tval(reqs, showresp=True).count("unprintables escaped") == 2 assert self.tval(reqs, showresp=True, hexdump=True).count("hex dump") == 2 def test_showresp_httperr(self): v = self.tval(["get:'/p/200:d20'"], showresp=True) assert "Invalid headers" in v assert "HTTP/" in v def test_explain(self): reqs = [ "get:/p/200:b@100" ] assert not "b@100" in self.tval(reqs, explain=True) 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 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'"]) def test_fileread(self): d = tutils.test_data.path("data/request") assert "foo" in self.tval(["+%s"%d], showreq=True) assert "File" in self.tval(["+/nonexistent"]) def test_connect_fail(self): to = ("foobar", 80) c = pathoc.Pathoc("127.0.0.1", self.d.port) r, w = cStringIO.StringIO(), cStringIO.StringIO() tutils.raises("connect failed", c.http_connect, to, w, r) r = cStringIO.StringIO( "HTTP/1.1 500 OK\r\n" ) tutils.raises("connect failed", c.http_connect, to, w, r) r = cStringIO.StringIO( "HTTP/1.1 200 OK\r\n" ) c.http_connect(to, w, r)