mirror of
https://github.com/emikulic/darkhttpd.git
synced 2023-08-10 21:13:08 +03:00
Add TestHelper.get()
This commit is contained in:
parent
81b1bcbd74
commit
de92584da1
@ -54,10 +54,16 @@ def parse(resp):
|
|||||||
return (status, hdrs, body)
|
return (status, hdrs, body)
|
||||||
|
|
||||||
class TestHelper(unittest.TestCase):
|
class TestHelper(unittest.TestCase):
|
||||||
|
def get(self, url, http_ver="1.0", endl="\n", req_hdrs={}, method="GET"):
|
||||||
|
self.curr_url = url
|
||||||
|
self.curr_conn = Conn()
|
||||||
|
return self.curr_conn.get(url, http_ver, endl, req_hdrs, method)
|
||||||
|
|
||||||
def assertContains(self, body, *strings):
|
def assertContains(self, body, *strings):
|
||||||
for s in strings:
|
for s in strings:
|
||||||
self.assertTrue(s in body,
|
self.assertTrue(s in body,
|
||||||
msg="expected %s in %s"%(repr(s), repr(body)))
|
msg="\nExpected: %s\nIn response: %s" % (
|
||||||
|
repr(s), repr(body)))
|
||||||
|
|
||||||
def assertIsIndex(self, body, path):
|
def assertIsIndex(self, body, path):
|
||||||
self.assertContains(body,
|
self.assertContains(body,
|
||||||
@ -94,7 +100,7 @@ class TestHelper(unittest.TestCase):
|
|||||||
|
|
||||||
def drive_range(self, range_in, range_out, len_out, data_out,
|
def drive_range(self, range_in, range_out, len_out, data_out,
|
||||||
status_out = "206 Partial Content"):
|
status_out = "206 Partial Content"):
|
||||||
resp = Conn().get(self.url, req_hdrs = {"Range": "bytes="+range_in})
|
resp = self.get(self.url, req_hdrs = {"Range": "bytes="+range_in})
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertContains(status, status_out)
|
self.assertContains(status, status_out)
|
||||||
self.assertEquals(hdrs["Accept-Ranges"], "bytes")
|
self.assertEquals(hdrs["Accept-Ranges"], "bytes")
|
||||||
@ -111,7 +117,7 @@ class TestDirList(TestHelper):
|
|||||||
os.unlink(self.fn)
|
os.unlink(self.fn)
|
||||||
|
|
||||||
def test_dirlist_escape(self):
|
def test_dirlist_escape(self):
|
||||||
resp = Conn().get("/")
|
resp = self.get("/")
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertEquals(ord("#"), 0x23)
|
self.assertEquals(ord("#"), 0x23)
|
||||||
self.assertContains(body, "escape%23this", "12345")
|
self.assertContains(body, "escape%23this", "12345")
|
||||||
@ -126,7 +132,7 @@ def makeCase(name, url, hdr_checker=None, body_checker=None,
|
|||||||
req_hdrs={"User-Agent": "test.py"},
|
req_hdrs={"User-Agent": "test.py"},
|
||||||
http_ver=None, endl="\n"):
|
http_ver=None, endl="\n"):
|
||||||
def do_test(self):
|
def do_test(self):
|
||||||
resp = Conn().get(url, http_ver, endl, req_hdrs)
|
resp = self.get(url, http_ver, endl, req_hdrs)
|
||||||
if http_ver is None:
|
if http_ver is None:
|
||||||
status = ""
|
status = ""
|
||||||
hdrs = {}
|
hdrs = {}
|
||||||
@ -194,7 +200,7 @@ class TestDirRedirect(TestHelper):
|
|||||||
os.rmdir(self.fn)
|
os.rmdir(self.fn)
|
||||||
|
|
||||||
def test_dir_redirect(self):
|
def test_dir_redirect(self):
|
||||||
resp = Conn().get(self.url)
|
resp = self.get(self.url)
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertContains(status, "301 Moved Permanently")
|
self.assertContains(status, "301 Moved Permanently")
|
||||||
self.assertEquals(hdrs["Location"], self.url+"/") # trailing slash
|
self.assertEquals(hdrs["Location"], self.url+"/") # trailing slash
|
||||||
@ -212,7 +218,7 @@ class TestFileGet(TestHelper):
|
|||||||
os.unlink(self.fn)
|
os.unlink(self.fn)
|
||||||
|
|
||||||
def get_helper(self, url):
|
def get_helper(self, url):
|
||||||
resp = Conn().get(url)
|
resp = self.get(url)
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertContains(status, "200 OK")
|
self.assertContains(status, "200 OK")
|
||||||
self.assertEquals(hdrs["Accept-Ranges"], "bytes")
|
self.assertEquals(hdrs["Accept-Ranges"], "bytes")
|
||||||
@ -237,7 +243,7 @@ class TestFileGet(TestHelper):
|
|||||||
self.get_helper(self.url + "?action=Submit")
|
self.get_helper(self.url + "?action=Submit")
|
||||||
|
|
||||||
def test_file_head(self):
|
def test_file_head(self):
|
||||||
resp = Conn().get(self.url, method="HEAD")
|
resp = self.get(self.url, method="HEAD")
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertContains(status, "200 OK")
|
self.assertContains(status, "200 OK")
|
||||||
self.assertEquals(hdrs["Accept-Ranges"], "bytes")
|
self.assertEquals(hdrs["Accept-Ranges"], "bytes")
|
||||||
@ -245,11 +251,11 @@ class TestFileGet(TestHelper):
|
|||||||
self.assertEquals(hdrs["Content-Type"], "image/jpeg")
|
self.assertEquals(hdrs["Content-Type"], "image/jpeg")
|
||||||
|
|
||||||
def test_if_modified_since(self):
|
def test_if_modified_since(self):
|
||||||
resp1 = Conn().get(self.url, method="HEAD")
|
resp1 = self.get(self.url, method="HEAD")
|
||||||
status, hdrs, body = parse(resp1)
|
status, hdrs, body = parse(resp1)
|
||||||
lastmod = hdrs["Last-Modified"]
|
lastmod = hdrs["Last-Modified"]
|
||||||
|
|
||||||
resp2 = Conn().get(self.url, method="GET", req_hdrs =
|
resp2 = self.get(self.url, method="GET", req_hdrs =
|
||||||
{"If-Modified-Since": lastmod })
|
{"If-Modified-Since": lastmod })
|
||||||
status, hdrs, body = parse(resp2)
|
status, hdrs, body = parse(resp2)
|
||||||
self.assertContains(status, "304 Not Modified")
|
self.assertContains(status, "304 Not Modified")
|
||||||
@ -272,7 +278,7 @@ class TestFileGet(TestHelper):
|
|||||||
1, self.data[-1])
|
1, self.data[-1])
|
||||||
|
|
||||||
def test_range_single_bad(self):
|
def test_range_single_bad(self):
|
||||||
resp = Conn().get(self.url, req_hdrs = {"Range":
|
resp = self.get(self.url, req_hdrs = {"Range":
|
||||||
"bytes=%d-%d"%(self.datalen, self.datalen)})
|
"bytes=%d-%d"%(self.datalen, self.datalen)})
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertContains(status, "416 Requested Range Not Satisfiable")
|
self.assertContains(status, "416 Requested Range Not Satisfiable")
|
||||||
@ -303,13 +309,13 @@ class TestFileGet(TestHelper):
|
|||||||
self.datalen, self.data)
|
self.datalen, self.data)
|
||||||
|
|
||||||
def test_range_bad_start(self):
|
def test_range_bad_start(self):
|
||||||
resp = Conn().get(self.url, req_hdrs = {"Range": "bytes=%d-"%(
|
resp = self.get(self.url, req_hdrs = {"Range": "bytes=%d-"%(
|
||||||
self.datalen*2)})
|
self.datalen*2)})
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertContains(status, "416 Requested Range Not Satisfiable")
|
self.assertContains(status, "416 Requested Range Not Satisfiable")
|
||||||
|
|
||||||
def test_range_backwards(self):
|
def test_range_backwards(self):
|
||||||
resp = Conn().get(self.url, req_hdrs = {"Range": "bytes=20-10"})
|
resp = self.get(self.url, req_hdrs = {"Range": "bytes=20-10"})
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertContains(status, "416 Requested Range Not Satisfiable")
|
self.assertContains(status, "416 Requested Range Not Satisfiable")
|
||||||
|
|
||||||
@ -358,7 +364,7 @@ class TestLargeFile2G(TestHelper):
|
|||||||
self.data[data_start:data_end])
|
self.data[data_start:data_end])
|
||||||
|
|
||||||
def test_largefile_head(self):
|
def test_largefile_head(self):
|
||||||
resp = Conn().get(self.url, method="HEAD")
|
resp = self.get(self.url, method="HEAD")
|
||||||
status, hdrs, body = parse(resp)
|
status, hdrs, body = parse(resp)
|
||||||
self.assertContains(status, "200 OK")
|
self.assertContains(status, "200 OK")
|
||||||
self.assertEquals(hdrs["Accept-Ranges"], "bytes")
|
self.assertEquals(hdrs["Accept-Ranges"], "bytes")
|
||||||
|
Loading…
Reference in New Issue
Block a user