Mercurial > hg > nginx-tests
view http_variables.t @ 251:df984d23f9d1
Tests: improve fastcgi keepalive tests.
On some platforms fastcgi_keepalive.t tests failed due to problems in
handling of data split into multiple packets. Harden tests to fail
on all platforms by adding more sleeps, and mark them as TODO till
underlying problems are fixed.
Additionally, add some padding testing.
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Fri, 25 Jan 2013 20:53:53 +0400 |
parents | 0ab1f0e978b5 |
children | 5ed8ef14f79c |
line wrap: on
line source
#!/usr/bin/perl # (C) Maxim Dounin # (C) Valentin Bartenev # Tests for http variables. ############################################################################### use warnings; use strict; use Test::More; BEGIN { use FindBin; chdir($FindBin::Bin); } use lib 'lib'; use Test::Nginx; ############################################################################### select STDERR; $| = 1; select STDOUT; $| = 1; my $t = Test::Nginx->new()->has(qw/http rewrite proxy/)->plan(3); $t->write_file_expand('nginx.conf', <<'EOF'); %%TEST_GLOBALS%% daemon off; events { } http { %%TEST_GLOBALS_HTTP%% log_format cc "$uri: $sent_http_cache_control"; server { listen 127.0.0.1:8080; server_name localhost; access_log %%TESTDIR%%/cc.log cc; location / { return 200 OK; } location /set { add_header Cache-Control max-age=3600; add_header Cache-Control private; add_header Cache-Control must-revalidate; return 200 OK; } location /redefine { expires epoch; proxy_pass http://127.0.0.1:8080/set; } } } EOF $t->run(); ############################################################################### http_get('/'); http_get('/redefine'); $t->stop(); my $log; { open LOG, $t->testdir() . '/cc.log' or die("Can't open nginx access log file.\n"); local $/; $log = <LOG>; close LOG; } like($log, qr!^/: -$!m, 'no header'); like($log, qr!^/set: max-age=3600; private; must-revalidate$!m, 'multi headers'); like($log, qr!^/redefine: no-cache$!m, 'ignoring headers with (hash == 0)'); ###############################################################################