Mercurial > hg > nginx-tests
annotate ssi_delayed.t @ 1606:e4e0695552ed
Tests: fixed stream_proxy_ssl_conf_command.t.
The stream_proxy_ssl_conf_command.t test used stream return module
to return the response. Since this ignores actual request, but the
perl test code used http_get(). This might result in the request being
sent after the response is returned and the connection closed by the server,
resulting in RST being generated and no response seen by the client at all.
Fix is to use "stream(...)->read()" instead of http_get(), so
no request is sent at all, eliminating possibility of RST being
generated.
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Tue, 10 Nov 2020 05:03:29 +0300 |
parents | 766bcbb632ee |
children |
rev | line source |
---|---|
1161
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
1 #!/usr/bin/perl |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
2 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
3 # (C) Andrey Zelenkov |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
4 # (C) Roman Arutyunyan |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
5 # (C) Nginx, Inc. |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
6 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
7 # Test for subrequest bug with delay (see 903fb1ddc07f for details). |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
8 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
9 ############################################################################### |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
10 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
11 use warnings; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
12 use strict; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
13 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
14 use Test::More; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
15 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
16 BEGIN { use FindBin; chdir($FindBin::Bin); } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
17 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
18 use lib 'lib'; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
19 use Test::Nginx; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
20 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
21 ############################################################################### |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
22 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
23 select STDERR; $| = 1; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
24 select STDOUT; $| = 1; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
25 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
26 my $t = Test::Nginx->new()->has(qw/http proxy ssi/)->plan(1); |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
27 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
28 $t->write_file_expand('nginx.conf', <<'EOF'); |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
29 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
30 %%TEST_GLOBALS%% |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
31 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
32 daemon off; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
33 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
34 events { |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
35 } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
36 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
37 http { |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
38 %%TEST_GLOBALS_HTTP%% |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
39 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
40 server { |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
41 listen 127.0.0.1:8080; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
42 server_name localhost; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
43 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
44 location / { } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
45 location /delayed.html { |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
46 ssi on; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
47 sendfile_max_chunk 100; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
48 postpone_output 0; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
49 } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
50 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
51 location /1 { |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
52 proxy_buffers 3 256; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
53 proxy_buffer_size 256; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
54 proxy_max_temp_file_size 0; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
55 proxy_pass http://127.0.0.1:8081; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
56 } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
57 } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
58 } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
59 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
60 EOF |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
61 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
62 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
63 $t->write_file('delayed.html', ('x' x 100) . '<!--#include virtual="/1"-->'); |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
64 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
65 $t->run_daemon(\&http_daemon); |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
66 $t->run()->waitforsocket('127.0.0.1:' . port(8081)); |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
67 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
68 ############################################################################### |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
69 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
70 # If a response sending is delayed by sendfile_max_chunk, and |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
71 # then we've switched to a different subrequest, which is not yet |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
72 # ready to handle corresponding write event, wev->delayed won't be |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
73 # cleared. This results in the subrequest response not being |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
74 # sent to the client, and the whole request will hang if all proxy |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
75 # buffers will be exhausted. Fixed in 1.11.13 (903fb1ddc07f). |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
76 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
77 like(http_get('/delayed.html'), qr/x{100}y{1024}SEE-THIS/, 'delayed'); |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
78 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
79 ############################################################################### |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
80 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
81 sub http_daemon { |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
82 my ($t) = @_; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
83 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
84 my $server = IO::Socket::INET->new( |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
85 Proto => 'tcp', |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
86 LocalHost => '127.0.0.1', |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
87 LocalPort => port(8081), |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
88 Listen => 5, |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
89 Reuse => 1 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
90 ) |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
91 or die "Can't create listening socket: $!\n"; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
92 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
93 local $SIG{PIPE} = 'IGNORE'; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
94 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
95 my $data = ('y' x 1024) . 'SEE-THIS'; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
96 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
97 while (my $client = $server->accept()) { |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
98 $client->autoflush(1); |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
99 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
100 my $headers = ''; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
101 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
102 while (<$client>) { |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
103 $headers .= $_; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
104 last if (/^\x0d?\x0a?$/); |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
105 } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
106 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
107 select undef, undef, undef, 0.5; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
108 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
109 print $client <<EOF; |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
110 HTTP/1.1 200 OK |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
111 Connection: close |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
112 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
113 $data |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
114 EOF |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
115 } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
116 } |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
117 |
e1225e304e46
Tests: special test with subrequest.
Andrey Zelenkov <zelenkov@nginx.com>
parents:
diff
changeset
|
118 ############################################################################### |