blob: d25534254bc704acd1e1f81ea1fb34d31233f672 [file] [log] [blame]
#!/usr/bin/perl
# (C) Maxim Dounin
# Tests for nginx limit_req 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(3);
$t->write_file_expand('nginx.conf', <<'EOF');
master_process off;
daemon off;
events {
}
http {
access_log off;
root %%TESTDIR%%;
client_body_temp_path %%TESTDIR%%/client_body_temp;
fastcgi_temp_path %%TESTDIR%%/fastcgi_temp;
proxy_temp_path %%TESTDIR%%/proxy_temp;
limit_req_zone $binary_remote_addr zone=one:10m rate=1r/m;
limit_req_zone $binary_remote_addr zone=long:10m rate=1r/m;
server {
listen 127.0.0.1:8080;
server_name localhost;
location / {
limit_req zone=one burst=1 nodelay;
}
location /long {
limit_req zone=long burst=5;
}
}
}
EOF
$t->write_file('test1.html', 'XtestX');
$t->write_file('long.html', "1234567890\n" x (1 << 16));
$t->run();
###############################################################################
like(http_get('/test1.html'), qr/^HTTP\/1.. 200 /m, 'request');
http_get('/test1.html');
like(http_get('/test1.html'), qr/^HTTP\/1.. 503 /m, 'request rejected');
TODO: {
local $TODO = "patch under review";
# Second request will be delayed by limit_req, make sure it isn't truncated.
# The bug only manifests itself if buffer will be filled, so sleep for a while
# before reading response.
my $l1 = length(http_get('/long.html'));
my $l2 = length(http_get('/long.html', sleep => 1.1));
is($l2, $l1, 'delayed big request not truncated');
}
###############################################################################