Mercurial > hg > nginx-tests
diff range.t @ 33:4f57d57543e1
Tests: range filter tests.
author | Maxim Dounin <mdounin@mdounin.ru> |
---|---|
date | Tue, 14 Oct 2008 02:18:03 +0400 |
parents | |
children | 7bf0e8a1d66c |
line wrap: on
line diff
new file mode 100644 --- /dev/null +++ b/range.t @@ -0,0 +1,120 @@ +#!/usr/bin/perl + +# (C) Maxim Dounin + +# Tests for range filter module. + +############################################################################### + +use warnings; +use strict; + +use Test::More; + +BEGIN { use FindBin; chdir($FindBin::Bin); } + +use lib 'lib'; +use Test::Nginx; + +############################################################################### + +select STDERR; $| = 1; +select STDOUT; $| = 1; + +my $t = Test::Nginx->new()->plan(25); + +$t->write_file_expand('nginx.conf', <<'EOF'); + +master_process off; +daemon off; + +events { + worker_connections 1024; +} + +http { + access_log off; + root %%TESTDIR%%; + + charset_map B A { + 58 59; # X -> Y + } + + server { + listen localhost:8080; + server_name localhost; + + location /t2.html { + charset A; + source_charset B; + } + } +} + +EOF + +$t->write_file('t1.html', + join('', map { sprintf "X%03dXXXXXX", $_ } (0 .. 99))); +$t->write_file('t2.html', + join('', map { sprintf "X%03dXXXXXX", $_ } (0 .. 99))); +$t->run(); + +############################################################################### + +my $t1; + +$t1 = http_get_range('/t1.html', 'Range: bytes=0-8'); +like($t1, qr/206/, 'range request - 206 partial reply'); +like($t1, qr/Content-Length: 9/, 'range request - correct length'); +like($t1, qr/Content-Range: bytes 0-8\/1000/, 'range request - content range'); +like($t1, qr/^X000XXXXX$/m, 'range request - correct content'); + +$t1 = http_get_range('/t1.html', 'Range: bytes=-10'); +like($t1, qr/206/, 'final bytes - 206 partial reply'); +like($t1, qr/Content-Length: 10/, 'final bytes - content length'); +like($t1, qr/Content-Range: bytes 990-999\/1000/, + 'final bytes - content range'); +like($t1, qr/^X099XXXXXX$/m, 'final bytes - correct content'); + +$t1 = http_get_range('/t1.html', 'Range: bytes=990-'); +like($t1, qr/206/, 'final bytes explicit - 206 partial reply'); +like($t1, qr/Content-Length: 10/, 'final bytes explicit - content length'); +like($t1, qr/Content-Range: bytes 990-999\/1000/, + 'final bytes explicit - content range'); +like($t1, qr/^X099XXXXXX$/m, 'final bytes explicit - correct content'); + +$t1 = http_get_range('/t1.html', 'Range: bytes=990-1990'); +like($t1, qr/206/, 'more than length - 206 partial reply'); +like($t1, qr/Content-Length: 10/, 'more than length - content length'); +like($t1, qr/Content-Range: bytes 990-999\/1000/, + 'more than length - content range'); +like($t1, qr/^X099XXXXXX$/m, 'more than length - correct content'); + +$t1 = http_get_range('/t2.html', 'Range: bytes=990-1990'); +like($t1, qr/206/, 'recoded - 206 partial reply'); +like($t1, qr/Content-Length: 10/, 'recoded - content length'); +like($t1, qr/Content-Range: bytes 990-999\/1000/, 'recoded - content range'); +like($t1, qr/^Y099YYYYYY$/m, 'recoded - correct content'); + +$t1 = http_get_range('/t1.html', 'Range: bytes=0-9, -10, 10-19'); +like($t1, qr/206/, 'multipart - 206 partial reply'); +like($t1, qr/Content-Type: multipart\/byteranges; boundary=/, + 'multipart - content type'); +like($t1, qr/X000XXXXXX/m, 'multipart - content 0-9'); +like($t1, qr/^X099XXXXXX\x0d?$/m, 'multipart - content -10 aka 990-999'); +like($t1, qr/X001XXXXXX\x0d?$/m, 'multipart - content 10-19'); + +############################################################################### + +sub http_get_range { + my ($url, $extra) = @_; + return http(<<EOF); +GET $url HTTP/1.1 +Host: localhost +Connection: close +$extra + +EOF +} + +###############################################################################