Mercurial > hg > nginx-tests
changeset 1056:1e41a0de0772
Tests: various last_buf tests.
author | Sergey Kandaurov <pluknet@nginx.com> |
---|---|
date | Wed, 12 Oct 2016 17:49:03 +0300 |
parents | 8979f0d86c29 |
children | e19d41512e22 |
files | addition_buffered.t mp4_ssi.t msie_refresh_ssi.t sub_filter_slice.t |
diffstat | 4 files changed, 350 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/addition_buffered.t Wed Oct 12 17:49:03 2016 +0300 @@ -0,0 +1,72 @@ +#!/usr/bin/perl + +# (C) Sergey Kandaurov +# (C) Nginx, Inc. + +# Tests for addition module with buffered data from other filters. + +# In particular, sub filter may have a partial match buffered. + +############################################################################### + +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()->has(qw/http proxy sub addition/)->plan(1); + +$t->write_file_expand('nginx.conf', <<'EOF'); + +%%TEST_GLOBALS%% + +daemon off; + +events { +} + +http { + %%TEST_GLOBALS_HTTP%% + + server { + listen 127.0.0.1:8080; + server_name localhost; + + location / { } + location /proxy/ { + sub_filter foo bar; + add_after_body /after.html; + proxy_pass http://127.0.0.1:8080/; + } + } +} + +EOF + +$t->write_file('after.html', 'after'); +$t->write_file('body.html', 'XXXXX'); + +$t->run(); + +############################################################################### + +# if data is buffered, there should be no interleaved data in output + +TODO: { +local $TODO = 'not yet' unless $t->has_version('1.11.5'); + +like(http_get('/proxy/body.html'), qr/^XXXXXafter$/m, 'request'); + +} + +###############################################################################
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mp4_ssi.t Wed Oct 12 17:49:03 2016 +0300 @@ -0,0 +1,90 @@ +#!/usr/bin/perl + +# (C) Sergey Kandaurov +# (C) Nginx, Inc. + +# Test for mp4 module in subrequests. + +############################################################################### + +use warnings; +use strict; + +use Test::More; + +use Config; + +BEGIN { use FindBin; chdir($FindBin::Bin); } + +use lib 'lib'; +use Test::Nginx; + +############################################################################### + +select STDERR; $| = 1; +select STDOUT; $| = 1; + +my $t = Test::Nginx->new()->has(qw/http mp4 ssi/)->has_daemon('ffprobe') + ->has_daemon('ffmpeg')->write_file_expand('nginx.conf', <<'EOF'); + +%%TEST_GLOBALS%% + +daemon off; + +events { +} + +http { + %%TEST_GLOBALS_HTTP%% + + server { + listen 127.0.0.1:8080; + server_name localhost; + + location / { + ssi on; + } + location /ssi { + mp4; + } + } +} + +EOF + +plan(skip_all => 'no lavfi') + unless grep /lavfi/, `ffmpeg -loglevel quiet -formats`; +system('ffmpeg -loglevel quiet -y ' + . '-f lavfi -i testsrc=duration=10:size=320x200:rate=15 ' + . '-f lavfi -i testsrc=duration=20:size=320x200:rate=15 ' + . '-map 0:0 -map 1:0 -pix_fmt yuv420p -g 15 -c:v libx264 ' + . "${\($t->testdir())}/ssi.mp4") == 0 + or die "Can't create mp4 file: $!"; + +$t->write_file('index.html', 'X<!--#include virtual="/ssi.mp4?end=1" -->X'); + +$t->run()->plan(1); + +############################################################################### + +TODO: { +local $TODO = 'not yet' unless $t->has_version('1.11.5'); + +(my $r = get('/')) =~ s/([^\x20-\x7e])/sprintf('\\x%02x', ord($1))/gmxe; +unlike($r, qr/\\x0d(\\x0a)?0\\x0d(\\x0a)?\\x0d(\\x0a)?\w/, 'only final chunk'); + +} + +############################################################################### + +sub get { + my ($url, $extra) = @_; + return http(<<EOF); +GET $url HTTP/1.1 +Host: localhost +Connection: close + +EOF +} + +###############################################################################
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/msie_refresh_ssi.t Wed Oct 12 17:49:03 2016 +0300 @@ -0,0 +1,80 @@ +#!/usr/bin/perl + +# (C) Sergey Kandaurov +# (C) Nginx, Inc. + +# Test for msie_refresh in subrequests. + +############################################################################### + +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()->has(qw/http rewrite ssi/)->plan(1) + ->write_file_expand('nginx.conf', <<'EOF'); + +%%TEST_GLOBALS%% + +daemon off; + +events { +} + +http { + %%TEST_GLOBALS_HTTP%% + + server { + listen 127.0.0.1:8080; + server_name localhost; + + location / { + ssi on; + } + location /ssi { + msie_refresh on; + return 301; + } + } +} + +EOF + +$t->write_file('index.html', 'X<!--#include virtual="/ssi.html" -->X'); +$t->run(); + +############################################################################### + +TODO: { +local $TODO = 'not yet' unless $t->has_version('1.11.5'); + +my $r = get('/', 'User-Agent: MSIE foo'); +unlike($r, qr/\x0d\x0a?0\x0d\x0a?\x0d\x0a?\w/, 'only final chunk'); + +} + +############################################################################### + +sub get { + my ($url, $extra) = @_; + return http(<<EOF); +GET $url HTTP/1.1 +Host: localhost +Connection: close +$extra + +EOF +} + +###############################################################################
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sub_filter_slice.t Wed Oct 12 17:49:03 2016 +0300 @@ -0,0 +1,108 @@ +#!/usr/bin/perl + +# (C) Sergey Kandaurov +# (C) Nginx, Inc. + +# Tests for slice filter with sub filter. + +# A response is sent using chunked encoding. + +############################################################################### + +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()->has(qw/http proxy slice sub/)->plan(3); + +$t->write_file_expand('nginx.conf', <<'EOF'); + +%%TEST_GLOBALS%% + +daemon off; + +events { +} + +http { + %%TEST_GLOBALS_HTTP%% + + server { + listen 127.0.0.1:8080; + server_name localhost; + + location / { + sub_filter foo bar; + sub_filter_types *; + + slice 2; + + proxy_pass http://127.0.0.1:8081/; + + proxy_set_header Range $slice_range; + } + } + + server { + listen 127.0.0.1:8081; + server_name localhost; + + location / { } + } +} + +EOF + +$t->write_file('t', '0123456789'); +$t->run(); + +############################################################################### + +my $r; + +TODO: { +local $TODO = 'not yet' unless $t->has_version('1.11.5'); + +# range filter in subrequests (subrequest_ranges) + +$r = get('/t', 'Range: bytes=2-4'); +unlike($r, qr/\x0d\x0a?0\x0d\x0a?\x0d\x0a?\w/, 'only final chunk'); + +} + +TODO: { +local $TODO = 'not yet'; + +# server is assumed to return the requested range + +$r = get('/t', 'Range: bytes=3-4'); +like($r, qr/ 206 /, 'range request - 206 partial reply'); +is(Test::Nginx::http_content($r), '34', 'range request - correct content'); + +} + +############################################################################### + +sub get { + my ($url, $extra) = @_; + return http(<<EOF); +GET $url HTTP/1.1 +Host: localhost +Connection: close +$extra + +EOF +} + +###############################################################################