Mercurial > hg > nginx-tests
annotate range_if_range.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 | d5bf5942a8b2 |
children | e9064d691790 |
rev | line source |
---|---|
173 | 1 #!/usr/bin/perl |
2 | |
3 # (C) Maxim Dounin | |
4 | |
5 # Tests for range filter module with If-Range header. | |
6 | |
7 ############################################################################### | |
8 | |
9 use warnings; | |
10 use strict; | |
11 | |
12 use Test::More; | |
13 | |
14 BEGIN { use FindBin; chdir($FindBin::Bin); } | |
15 | |
16 use lib 'lib'; | |
17 use Test::Nginx; | |
18 | |
19 ############################################################################### | |
20 | |
21 select STDERR; $| = 1; | |
22 select STDOUT; $| = 1; | |
23 | |
24 my $t = Test::Nginx->new()->has(qw/http/)->plan(8); | |
25 | |
26 $t->write_file_expand('nginx.conf', <<'EOF'); | |
27 | |
28 %%TEST_GLOBALS%% | |
29 | |
249
6a0d934950bc
Tests: remove extra spaces in "daemon off".
Maxim Dounin <mdounin@mdounin.ru>
parents:
242
diff
changeset
|
30 daemon off; |
173 | 31 |
32 events { | |
33 } | |
34 | |
35 http { | |
36 %%TEST_GLOBALS_HTTP%% | |
37 | |
38 server { | |
39 listen 127.0.0.1:8080; | |
40 server_name localhost; | |
41 | |
42 location /t2.html { | |
43 add_header Last-Modified ""; | |
44 } | |
45 | |
46 location /t3.html { | |
47 add_header Last-Modified "Mon, 28 Sep 1970 06:00:00 GMT"; | |
48 } | |
49 } | |
50 } | |
51 | |
52 EOF | |
53 | |
54 $t->write_file('t1.html', | |
55 join('', map { sprintf "X%03dXXXXXX", $_ } (0 .. 99))); | |
56 $t->write_file('t2.html', | |
57 join('', map { sprintf "X%03dXXXXXX", $_ } (0 .. 99))); | |
58 $t->write_file('t3.html', | |
59 join('', map { sprintf "X%03dXXXXXX", $_ } (0 .. 99))); | |
60 $t->run(); | |
61 | |
62 ############################################################################### | |
63 | |
64 my $t1; | |
65 | |
66 # If-Range | |
67 | |
68 $t1 = http_get_range('/t1.html', "Range: bytes=0-9\nIf-Range: wrong"); | |
69 like($t1, qr/200 OK/, 'if-range wrong'); | |
70 like($t1, qr/Last-Modified: /, 'if-range wrong - last modified'); | |
71 | |
72 $t1 =~ m/Last-Modified: (.*)/m; | |
73 my $last = $1; | |
74 | |
75 $t1 = http_get_range('/t1.html', "Range: bytes=0-9\nIf-Range: $last"); | |
491
d5bf5942a8b2
Tests: disambiguated parsing of the status code.
Sergey Kandaurov <pluknet@nginx.com>
parents:
317
diff
changeset
|
76 like($t1, qr/ 206 /, 'if-range'); |
173 | 77 |
78 # If-Range + add_header Last-Modified "" | |
79 | |
80 $t1 = http_get_range('/t2.html', "Range: bytes=0-9\nIf-Range: wrong"); | |
81 like($t1, qr/200 OK/, 'if-range notime'); | |
82 unlike($t1, qr/Last-Modified: /, 'if-range notime - no last modified'); | |
83 | |
84 # If-Range + add_header Last-Modified "Mon, 28 Sep 1970 06:00:00 GMT" | |
85 | |
86 $t1 = http_get_range('/t3.html', "Range: bytes=0-9\nIf-Range: wrong"); | |
87 like($t1, qr/200 OK/, 'if-range time wrong'); | |
88 like($t1, qr/Last-Modified: Mon, 28 Sep 1970 06:00:00 GMT/, | |
89 'if-range time wrong - last modified'); | |
90 | |
91 $t1 = http_get_range('/t3.html', | |
92 "Range: bytes=0-9\nIf-Range: Mon, 28 Sep 1970 06:00:00 GMT"); | |
491
d5bf5942a8b2
Tests: disambiguated parsing of the status code.
Sergey Kandaurov <pluknet@nginx.com>
parents:
317
diff
changeset
|
93 like($t1, qr/ 206 /, 'if-range time'); |
173 | 94 |
95 ############################################################################### | |
96 | |
97 sub http_get_range { | |
98 my ($url, $extra) = @_; | |
99 return http(<<EOF); | |
100 GET $url HTTP/1.1 | |
101 Host: localhost | |
102 Connection: close | |
103 $extra | |
104 | |
105 EOF | |
106 } | |
107 | |
108 ############################################################################### |