blob: b1fa7ddb0887658ffcde6bb628096eb706d37050 [file] [log] [blame]
#!/usr/bin/perl
# (C) Andrey Zelenkov
# (C) Nginx, Inc.
# Tests for stub status 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()->has(qw/http stub_status/)->plan(34);
$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;
add_header X-Active $connections_active;
add_header X-Reading $connections_reading;
add_header X-Writing $connections_writing;
add_header X-Waiting $connections_waiting;
location / { }
location /rate {
limit_rate 15;
}
location /stub {
stub_status;
}
}
}
EOF
$t->write_file('index.html', '');
$t->run();
###############################################################################
my %status = status('/stub');
like(http_get('/stub'), qr/200 OK/, 'get request');
is($status{'active'}, 1, 'open connection');
is($status{'requests'}, 1, 'first request');
is($status{'accepts'}, 1, 'first request accepted');
is($status{'handled'}, 1, 'first request handled');
is($status{'writing'}, 1, 'first response');
is($status{'reading'}, 0, 'not reading');
# pipelined requests
http(<<EOF);
GET / HTTP/1.1
Host: localhost
GET / HTTP/1.1
Host: localhost
Connection: close
EOF
%status = status('/stub');
is($status{'requests'}, 5, 'requests increased by 2');
is($status{'accepts'}, 4, 'accepts increased by 1');
# states
my $s = http('', start => 1);
%status = status('/stub');
is($status{'active'}, 2, 'active');
is($status{'waiting'}, 1, 'waiting state');
is($status{'reading'}, 0, 'waiting state - not reading');
is($status{'writing'}, 1, 'waiting state - not writing');
http(<<EOF, start => 1, socket => $s, sleep => 0.2);
GET /rate HTTP/1.0
EOF
%status = status('/stub');
is($status{'waiting'}, 0, 'reading state - not waiting');
is($status{'reading'}, 1, 'reading state');
is($status{'writing'}, 1, 'reading state - not writing');
http(<<EOF, start => 1, socket => $s, sleep => 0.2);
Host: localhost
EOF
%status = status('/stub');
is($status{'waiting'}, 0, 'writing state - not waiting');
is($status{'reading'}, 0, 'writing state - not reading');
is($status{'writing'}, 2, 'writing state');
$s->close();
# head and post requests
like(http_head('/stub'), qr/200 OK/, 'head request');
like(http_post('/stub'), qr/405 Not Allowed/, 'post request');
# embedded variables in headers
my $r = http_get('/stub');
like($r, qr/X-Active: 1/, 'get - var active');
like($r, qr/X-Reading: 0/, 'get - var reading');
like($r, qr/X-Writing: 1/, 'get - var writing');
like($r, qr/X-Waiting: 0/, 'get - var waiting');
$r = http_head('/stub');
like($r, qr/X-Active: 1/, 'head - var active');
like($r, qr/X-Reading: 0/, 'head - var reading');
like($r, qr/X-Writing: 1/, 'head - var writing');
like($r, qr/X-Waiting: 0/, 'head - var waiting');
is(get_body($r), '', 'head - empty body');
$r = http_get('/');
like($r, qr/X-Active: 1/, 'no stub - var active');
like($r, qr/X-Reading: 0/, 'no stub - var reading');
like($r, qr/X-Writing: 1/, 'no stub - var writing');
like($r, qr/X-Waiting: 0/, 'no stub - var waiting');
###############################################################################
sub get_body {
my ($r) = @_;
$r =~ /.*?\x0d\x0a?\x0d\x0a?(.*)/ms;
return $1;
}
sub http_post {
my ($url) = @_;
return http(<<EOF);
POST $url HTTP/1.0
Host: localhost
EOF
}
sub status {
my ($url) = @_;
my $r = http_get($url);
$r =~ /
Active\ connections:\ +(\d+)
\s+server\ accepts\ handled\ requests
\s+(\d+)\ +(\d+)\ +(\d+)
\s+Reading:\ +(\d+)
\s+Writing:\ +(\d+)
\s+Waiting:\ +(\d+)
/sx;
return ('active' => $1,
'accepts' => $2,
'handled' => $3,
'requests' => $4,
'reading' => $5,
'writing' => $6,
'waiting' => $7,
);
}
###############################################################################