annotate proxy_cache_variables.t @ 570:f7bc1f74970a

Tests: avoid send errors in syslog tests with mail error_log. Use a separate mail server block for syslog parsing tests to make sure that syslog messages are always read by the receiver on the remote side. Otherwise, syslog message might not be sent due to a pending socket error.
author Sergey Kandaurov <pluknet@nginx.com>
date Thu, 07 May 2015 14:28:44 +0300
parents 907e89fba9c3
children 2cd00179f4b2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
517
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
1 #!/usr/bin/perl
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
2
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
3 # (C) Sergey Kandaurov
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
4 # (C) Nginx, Inc.
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
5
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
6 # Tests for http proxy cache, proxy_cache directive with variables.
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
7
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
8 ###############################################################################
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
9
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
10 use warnings;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
11 use strict;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
12
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
13 use Test::More;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
14
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
15 BEGIN { use FindBin; chdir($FindBin::Bin); }
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
16
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
17 use lib 'lib';
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
18 use Test::Nginx;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
19
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
20 ###############################################################################
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
21
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
22 select STDERR; $| = 1;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
23 select STDOUT; $| = 1;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
24
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
25 plan(skip_all => 'win32') if $^O eq 'MSWin32';
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
26
568
907e89fba9c3 Tests: removed TODO and try_run() checks for legacy versions.
Sergey Kandaurov <pluknet@nginx.com>
parents: 517
diff changeset
27 my $t = Test::Nginx->new()->has(qw/http proxy cache/)->plan(9)
517
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
28 ->write_file_expand('nginx.conf', <<'EOF');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
29
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
30 %%TEST_GLOBALS%%
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
31
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
32 daemon off;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
33
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
34 events {
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
35 }
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
36
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
37 http {
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
38 %%TEST_GLOBALS_HTTP%%
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
39
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
40 proxy_cache_path %%TESTDIR%%/cache1 levels=1:2
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
41 keys_zone=NAME1:1m;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
42 proxy_cache_path %%TESTDIR%%/cache2 levels=1:2
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
43 keys_zone=NAME2:1m;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
44
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
45 server {
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
46 listen 127.0.0.1:8080;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
47 server_name localhost;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
48
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
49 location / {
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
50 proxy_pass http://127.0.0.1:8081;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
51
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
52 proxy_cache $arg_c;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
53
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
54 proxy_cache_valid any 1m;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
55
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
56 add_header X-Cache-Status $upstream_cache_status;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
57 }
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
58 }
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
59
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
60 server {
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
61 listen 127.0.0.1:8081;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
62 server_name localhost;
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
63
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
64 location / {
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
65 }
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
66 }
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
67 }
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
68
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
69 EOF
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
70
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
71 $t->write_file('index.html', 'SEE-THIS');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
72
568
907e89fba9c3 Tests: removed TODO and try_run() checks for legacy versions.
Sergey Kandaurov <pluknet@nginx.com>
parents: 517
diff changeset
73 $t->run();
517
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
74
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
75 ###############################################################################
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
76
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
77 like(http_get('/?c=NAME1'), qr/MISS.*SEE-THIS/ms, 'proxy request');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
78 like(http_get('/?c=NAME1'), qr/HIT.*SEE-THIS/ms, 'proxy request cached');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
79
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
80 unlike(http_head('/?c=NAME1'), qr/SEE-THIS/, 'head request');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
81
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
82 $t->write_file('index.html', 'SEE-THAT');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
83
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
84 like(http_get('/?c=NAME2'), qr/MISS.*SEE-THAT/ms, 'proxy request 2');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
85 like(http_get('/?c=NAME2'), qr/HIT.*SEE-THAT/ms, 'proxy request 2 cached');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
86
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
87 # some invalid cases
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
88
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
89 like(http_get('/?c=NAME'), qr/ 500 /, 'proxy_cache unknown');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
90 like(http_get('/'), qr/(?<!X-Cache).*SEE-THAT/ms, 'proxy_cache empty');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
91
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
92 $t->write_file('index.html', 'SEE-THOSE');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
93
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
94 like(http_get('/'), qr/SEE-THOSE/, 'proxy_cache empty - not cached');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
95
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
96 like(`grep -F '[alert]' ${\($t->testdir())}/error.log`, qr/^$/s, 'no alerts');
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
97
b2c3d509b2f9 Tests: proxy_cache with variables.
Sergey Kandaurov <pluknet@nginx.com>
parents:
diff changeset
98 ###############################################################################