annotate scgi_cache.t @ 386:1b205a3332de

Tests: adjusted limit_req rate value. This shortens excessive test execution time due to unnecessarily delayed backend connection after client connection close, which is usually observed when the client connection is closed before the request is proxied to backend.
author Sergey Kandaurov <pluknet@nginx.com>
date Wed, 26 Mar 2014 22:50:22 +0400
parents e9de4da234c0
children 847ea345becb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
308
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
1 #!/usr/bin/perl
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
2
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
3 # (C) Maxim Dounin
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
4
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
5 # Tests for scgi_cache.
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
6
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
7 ###############################################################################
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
8
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
9 use warnings;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
10 use strict;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
11
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
12 use Test::More;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
13 use Socket qw/ CRLF /;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
14
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
15 BEGIN { use FindBin; chdir($FindBin::Bin); }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
16
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
17 use lib 'lib';
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
18 use Test::Nginx;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
19
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
20 ###############################################################################
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
21
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
22 select STDERR; $| = 1;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
23 select STDOUT; $| = 1;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
24
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
25 eval { require SCGI; };
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
26 plan(skip_all => 'SCGI not installed') if $@;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
27
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
28 my $t = Test::Nginx->new()->has(qw/http scgi cache/)->plan(10)
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
29 ->write_file_expand('nginx.conf', <<'EOF');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
30
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
31 %%TEST_GLOBALS%%
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
32
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
33 daemon off;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
34
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
35 events {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
36 }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
37
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
38 http {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
39 %%TEST_GLOBALS_HTTP%%
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
40
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
41 scgi_cache_path %%TESTDIR%%/cache keys_zone=one:1m;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
42 scgi_cache_key $request_uri;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
43
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
44 add_header X-Cache-Status $upstream_cache_status;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
45
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
46 server {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
47 listen 127.0.0.1:8080;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
48 server_name localhost;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
49
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
50 location / {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
51 scgi_pass 127.0.0.1:8081;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
52 scgi_param SCGI 1;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
53 scgi_param REQUEST_URI $uri;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
54 scgi_cache one;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
55 }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
56 }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
57 }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
58
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
59 EOF
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
60
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
61 $t->run_daemon(\&scgi_daemon);
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
62 $t->run();
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
63
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
64 ###############################################################################
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
65
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
66 like(http_get('/len'), qr/MISS/, 'length');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
67 like(http_get('/len'), qr/HIT/, 'length cached');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
68
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
69 like(http_get('/nolen'), qr/MISS/, 'no length');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
70 like(http_get('/nolen'), qr/HIT/, 'no length cached');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
71
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
72 like(http_get('/len/empty'), qr/MISS/, 'empty length');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
73
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
74 TODO: {
319
e9de4da234c0 Tests: add version checks to TODOs for committed patches.
Maxim Dounin <mdounin@mdounin.ru>
parents: 308
diff changeset
75 local $TODO = 'not yet' unless $t->has_version('1.5.3');
308
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
76
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
77 like(http_get('/len/empty'), qr/HIT/, 'empty length cached');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
78 }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
79
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
80 like(http_get('/nolen/empty'), qr/MISS/, 'empty no length');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
81 like(http_get('/nolen/empty'), qr/HIT/, 'empty no length cached');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
82
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
83 like(http_get('/unfinished'), qr/MISS/, 'unfinished');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
84 like(http_get('/unfinished'), qr/MISS/, 'unfinished not cached');
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
85
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
86 ###############################################################################
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
87
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
88 sub scgi_daemon {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
89 my $server = IO::Socket::INET->new(
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
90 Proto => 'tcp',
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
91 LocalHost => '127.0.0.1:8081',
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
92 Listen => 5,
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
93 Reuse => 1
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
94 )
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
95 or die "Can't create listening socket: $!\n";
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
96
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
97 my $scgi = SCGI->new($server, blocking => 1);
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
98 my %count;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
99
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
100 while (my $request = $scgi->accept()) {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
101 $request->read_env();
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
102
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
103 my $uri = $request->env->{REQUEST_URI} || '';
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
104 my $c = $request->connection();
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
105
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
106 $count{$uri} ||= 0;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
107 $count{$uri}++;
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
108
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
109 if ($uri eq '/len') {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
110 $c->print(
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
111 "Content-Length: 9" . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
112 "Content-Type: text/html" . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
113 "Cache-Control: max-age=300" . CRLF . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
114 "test body"
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
115 );
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
116
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
117 } elsif ($uri eq '/nolen') {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
118 $c->print(
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
119 "Content-Type: text/html" . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
120 "Cache-Control: max-age=300" . CRLF . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
121 "test body"
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
122 );
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
123
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
124 } elsif ($uri eq '/len/empty') {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
125 $c->print(
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
126 "Content-Length: 0" . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
127 "Content-Type: text/html" . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
128 "Cache-Control: max-age=300" . CRLF . CRLF
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
129 );
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
130
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
131 } elsif ($uri eq '/nolen/empty') {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
132 $c->print(
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
133 "Content-Type: text/html" . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
134 "Cache-Control: max-age=300" . CRLF . CRLF
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
135 );
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
136
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
137 } elsif ($uri eq '/unfinished') {
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
138 $c->print(
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
139 "Content-Length: 10" . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
140 "Content-Type: text/html" . CRLF .
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
141 "Cache-Control: max-age=300" . CRLF . CRLF
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
142 );
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
143 }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
144 }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
145 }
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
146
26147426718c Tests: scgi cache tests.
Maxim Dounin <mdounin@mdounin.ru>
parents:
diff changeset
147 ###############################################################################