Mercurial > hg > nginx-tests
view proxy_limit_rate.t @ 598:153969b53780
Tests: expect occasional alerts on solaris in certain tests.
They may be produced as follows with the default "/dev/poll" event method.
[alert] 20775#1: phantom event 0004 for closed and removed socket 17
In proxy_unfinished.t, this is caused by closing upstream connection with
repeated read event notifications after EOF, and in stream_proxy_ssl_verify.t,
this is due to finalizing stream proxy before stream proxy connected upstream.
author | Sergey Kandaurov <pluknet@nginx.com> |
---|---|
date | Mon, 01 Jun 2015 21:15:32 +0300 |
parents | 907e89fba9c3 |
children | cb35a9ec4428 |
line wrap: on
line source
#!/usr/bin/perl # (C) Sergey Kandaurov # (C) Nginx, Inc. # Tests for the proxy_limit_rate directive. ############################################################################### 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/)->plan(2); $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 / { proxy_pass http://127.0.0.1:8080/data; proxy_limit_rate 12000; add_header X-Msec $msec; } location /data { } } } EOF $t->write_file('data', 'X' x 40000); $t->run(); ############################################################################### my $r = http_get('/'); my ($t1) = $r =~ /X-Msec: (\d+)/; my $diff = time() - $t1; # four chunks are split with three 1s delays + 1s error cmp_ok(abs($diff - 3), '<=', 1, 'proxy_limit_rate'); like($r, qr/^(XXXXXXXXXX){4000}\x0d?\x0a?$/m, 'response body'); ###############################################################################