blob: 35be946e9f7cfde9b2bddcdb4426058cfb6b198e [file] [log] [blame]
#!/usr/bin/perl
# (C) Andrey Zelenkov
# (C) Nginx, Inc.
# Tests for request_id variable.
###############################################################################
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/)
->write_file_expand('nginx.conf', <<'EOF');
%%TEST_GLOBALS%%
daemon off;
events {
}
http {
%%TEST_GLOBALS_HTTP%%
log_format id $request_id;
server {
listen 127.0.0.1:8080;
server_name localhost;
add_header X-Request-Id $request_id;
add_header X-blah blah;
location / {
ssi on;
}
location /body {
return 200 $request_id;
}
location /log {
access_log %%TESTDIR%%/id.log id;
return 200;
}
}
}
EOF
$t->write_file('index.html', '');
$t->write_file('add.html', '<!--#include virtual="/body" -->');
$t->run()->plan(12);
###############################################################################
my ($id1) = http_get('/') =~ qr/^X-Request-Id: (.*)\x0d/m;
my ($id2) = http_get('/') =~ qr/^X-Request-Id: (.*)\x0d/m;
like($id1, qr/^[a-z0-9]{32}$/, 'format id 1');
like($id2, qr/^[a-z0-9]{32}$/, 'format id 2');
isnt($id1, $id2, 'different id');
# same request
($id1, $id2) = http_get('/body')
=~ qr/^X-Request-Id: (.*?)\x0d.*\x0d\x0a(.*)/ms;
like($id1, qr/^[a-z0-9]{32}$/, 'format id 1 - same');
like($id2, qr/^[a-z0-9]{32}$/, 'format id 2 - same');
is($id1, $id2, 'equal id - same');
# subrequest
($id1, $id2) = http_get('/add.html')
=~ qr/^X-Request-Id: (.*?)\x0d.*\x0d\x0a(.*)/ms;
like($id1, qr/^[a-z0-9]{32}$/, 'format id 1 - sub');
like($id2, qr/^[a-z0-9]{32}$/, 'format id 2 - sub');
is($id1, $id2, 'equal id - sub');
# log
($id1) = http_get('/log') =~ qr/^X-Request-Id: (.*)\x0d/m;
$t->stop();
$id2 = $t->read_file('/id.log');
chomp $id2;
like($id1, qr/^[a-z0-9]{32}$/, 'format id 1 - log');
like($id2, qr/^[a-z0-9]{32}$/, 'format id 2 - log');
is($id1, $id2, 'equal id - log');
###############################################################################