Mercurial > hg > nginx-tests
view gzip.t @ 107:1c0ec30614c6
Tests: add TEST_GLOBALS and TEST_GLOBALS_HTTP config chunks.
TEST_GLOBALS replaces previously used -g switch. This allows tests
to be executed on 0.6.* branch. For compatibility with old tests -g switch
will be used if TEST_GLOBALS wasn't expaneded in config.
TEST_GLOBALS_HTTP replaces multiple variables (access_log, root,
client_body_temp_path, proxy_temp_path, fastcgi_temp_path) previously
specified directly in test configs. This change reduce duplication and
allows tests to be used with nginx compiled without fastcgi and/or proxy
modules (as proxy_temp_path and fastcgi_temp_path are added conditionally).
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Wed, 14 Oct 2009 02:23:52 +0400 |
parents | 8bc9de6559a1 |
children | c8341d95297e |
line wrap: on
line source
#!/usr/bin/perl # (C) Maxim Dounin # Tests for nginx gzip filter module. ############################################################################### use warnings; use strict; use Test::More; BEGIN { use FindBin; chdir($FindBin::Bin); } use lib 'lib'; use Test::Nginx qw/ :DEFAULT :gzip /; ############################################################################### select STDERR; $| = 1; select STDOUT; $| = 1; my $t = Test::Nginx->new()->has('gzip')->plan(6); $t->write_file_expand('nginx.conf', <<'EOF'); %%TEST_GLOBALS%% master_process off; daemon off; events { } http { %%TEST_GLOBALS_HTTP%% server { listen 127.0.0.1:8080; server_name localhost; location / { gzip on; } location /proxy/ { gzip on; proxy_pass http://127.0.0.1:8080/local/; } location /local/ { gzip off; alias %%TESTDIR%%/; } } } EOF $t->write_file('index.html', 'X' x 64); $t->run(); ############################################################################### my $r; $r = http_gzip_request('/'); like($r, qr/^Content-Encoding: gzip/m, 'gzip'); http_gzip_like($r, qr/^X{64}\Z/, 'gzip content correct'); $r = http_gzip_request('/proxy/'); like($r, qr/^Content-Encoding: gzip/m, 'gzip proxied'); http_gzip_like($r, qr/^X{64}\Z/, 'gzip proxied content'); # Accept-Ranges headers should be cleared unlike(http_gzip_request('/'), qr/Accept-Ranges/im, 'cleared accept-ranges'); unlike(http_gzip_request('/proxy/'), qr/Accept-Ranges/im, 'cleared headers from proxy'); ###############################################################################