| 1 |
import test |
|---|
| 2 |
test.prefer_parent_path() |
|---|
| 3 |
|
|---|
| 4 |
import gzip, StringIO |
|---|
| 5 |
import cherrypy |
|---|
| 6 |
|
|---|
| 7 |
def setup_server(): |
|---|
| 8 |
class Root: |
|---|
| 9 |
def index(self): |
|---|
| 10 |
yield "Hello, world" |
|---|
| 11 |
index.exposed = True |
|---|
| 12 |
|
|---|
| 13 |
def noshow(self): |
|---|
| 14 |
|
|---|
| 15 |
|
|---|
| 16 |
raise IndexError() |
|---|
| 17 |
yield "Here be dragons" |
|---|
| 18 |
noshow.exposed = True |
|---|
| 19 |
|
|---|
| 20 |
def noshow_stream(self): |
|---|
| 21 |
|
|---|
| 22 |
|
|---|
| 23 |
raise IndexError() |
|---|
| 24 |
yield "Here be dragons" |
|---|
| 25 |
noshow_stream.exposed = True |
|---|
| 26 |
|
|---|
| 27 |
cherrypy.root = Root() |
|---|
| 28 |
cherrypy.config.update({ |
|---|
| 29 |
'global': {'server.log_to_screen': False, |
|---|
| 30 |
'server.environment': 'production', |
|---|
| 31 |
'server.show_tracebacks': True, |
|---|
| 32 |
'gzip_filter.on': True, |
|---|
| 33 |
}, |
|---|
| 34 |
'/noshow_stream': {'stream_response': True}, |
|---|
| 35 |
}) |
|---|
| 36 |
|
|---|
| 37 |
|
|---|
| 38 |
import helper |
|---|
| 39 |
|
|---|
| 40 |
europoundUtf8 = u'\x80\xa3'.encode('utf-8') |
|---|
| 41 |
|
|---|
| 42 |
class GzipFilterTest(helper.CPWebCase): |
|---|
| 43 |
|
|---|
| 44 |
def testGzipFilter(self): |
|---|
| 45 |
zbuf = StringIO.StringIO() |
|---|
| 46 |
zfile = gzip.GzipFile(mode='wb', fileobj=zbuf, compresslevel=9) |
|---|
| 47 |
zfile.write("Hello, world") |
|---|
| 48 |
zfile.close() |
|---|
| 49 |
|
|---|
| 50 |
self.getPage('/', headers=[("Accept-Encoding", "gzip")]) |
|---|
| 51 |
self.assertInBody(zbuf.getvalue()[:3]) |
|---|
| 52 |
self.assertHeader("Vary", "Accept-Encoding") |
|---|
| 53 |
|
|---|
| 54 |
|
|---|
| 55 |
self.getPage('/', headers=[("Accept-Encoding", "identity")]) |
|---|
| 56 |
self.assertNoHeader("Vary") |
|---|
| 57 |
self.assertBody("Hello, world") |
|---|
| 58 |
|
|---|
| 59 |
self.getPage('/', headers=[("Accept-Encoding", "gzip;q=0")]) |
|---|
| 60 |
self.assertNoHeader("Vary") |
|---|
| 61 |
self.assertBody("Hello, world") |
|---|
| 62 |
|
|---|
| 63 |
self.getPage('/', headers=[("Accept-Encoding", "*;q=0")]) |
|---|
| 64 |
self.assertStatus(406) |
|---|
| 65 |
self.assertNoHeader("Vary") |
|---|
| 66 |
self.assertErrorPage(406, "identity, gzip") |
|---|
| 67 |
|
|---|
| 68 |
|
|---|
| 69 |
self.getPage('/noshow', headers=[("Accept-Encoding", "gzip")]) |
|---|
| 70 |
self.assertNoHeader('Content-Encoding') |
|---|
| 71 |
self.assertStatus(500) |
|---|
| 72 |
self.assertErrorPage(500, pattern="IndexError\n") |
|---|
| 73 |
|
|---|
| 74 |
|
|---|
| 75 |
|
|---|
| 76 |
|
|---|
| 77 |
|
|---|
| 78 |
self.getPage('/noshow_stream', |
|---|
| 79 |
headers=[("Accept-Encoding", "gzip")]) |
|---|
| 80 |
self.assertHeader('Content-Encoding', 'gzip') |
|---|
| 81 |
self.assertMatchesBody(r"Unrecoverable error in the server.$") |
|---|
| 82 |
|
|---|
| 83 |
|
|---|
| 84 |
if __name__ == "__main__": |
|---|
| 85 |
setup_server() |
|---|
| 86 |
helper.testmain() |
|---|