Mercurial > hg > nginx-tests
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 |
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 ############################################################################### |