blob: 5bb4325491b32120fe343f6b50bd5e061a3870e2 [file] [log] [blame] [raw]
# vi:filetype=
use lib 'lib';
use Test::Nginx::Socket;
repeat_each(2);
plan tests => repeat_each() * (blocks() * 2 + 1);
#$Test::Nginx::LWP::LogLevel = 'debug';
$ENV{TEST_NGINX_HTML_DIR} = html_dir;
run_tests();
__DATA__
=== TEST 1: sanity - GET
--- config
location /main {
echo_subrequest_async GET /sub;
}
location /sub {
echo "sub method: $echo_request_method";
echo "main method: $echo_client_request_method";
}
--- request
GET /main
--- response_body
sub method: GET
main method: GET
=== TEST 2: sanity - DELETE
--- config
location /main {
echo_subrequest_async DELETE /sub;
}
location /sub {
echo "sub method: $echo_request_method";
echo "main method: $echo_client_request_method";
}
--- request
GET /main
--- response_body
sub method: DELETE
main method: GET
=== TEST 3: trailing echo
--- config
location /main {
echo_subrequest_async GET /sub;
echo after subrequest;
}
location /sub {
echo hello;
}
--- request
GET /main
--- response_body
hello
after subrequest
=== TEST 4: leading echo
--- config
location /main {
echo before subrequest;
echo_subrequest_async GET /sub;
}
location /sub {
echo hello;
}
--- request
GET /main
--- response_body
before subrequest
hello
=== TEST 5: leading & trailing echo
--- config
location /main {
echo before subrequest;
echo_subrequest_async GET /sub;
echo after subrequest;
}
location /sub {
echo hello;
}
--- request
GET /main
--- response_body
before subrequest
hello
after subrequest
=== TEST 6: multiple subrequests
--- config
location /main {
echo before sr 1;
echo_subrequest_async GET /sub;
echo after sr 1;
echo before sr 2;
echo_subrequest_async GET /sub;
echo after sr 2;
}
location /sub {
echo hello;
}
--- request
GET /main
--- response_body
before sr 1
hello
after sr 1
before sr 2
hello
after sr 2
=== TEST 7: timed multiple subrequests (blocking sleep)
--- config
location /main {
echo_reset_timer;
echo_subrequest_async GET /sub1;
echo_subrequest_async GET /sub2;
echo "took $echo_timer_elapsed sec for total.";
}
location /sub1 {
echo_blocking_sleep 0.02;
echo hello;
}
location /sub2 {
echo_blocking_sleep 0.01;
echo world;
}
--- request
GET /main
--- response_body_like
^hello
world
took 0\.00[0-5] sec for total\.$
=== TEST 8: timed multiple subrequests (non-blocking sleep)
--- config
location /main {
echo_reset_timer;
echo_subrequest_async GET /sub1;
echo_subrequest_async GET /sub2;
echo "took $echo_timer_elapsed sec for total.";
}
location /sub1 {
echo_sleep 0.02;
echo hello;
}
location /sub2 {
echo_sleep 0.01;
echo world;
}
--- request
GET /main
--- response_body_like
^hello
world
took 0\.00[0-5] sec for total\.$
=== TEST 9: location with args
--- config
location /main {
echo_subrequest_async GET /sub -q 'foo=Foo&bar=Bar';
}
location /sub {
echo $arg_foo $arg_bar;
}
--- request
GET /main
--- response_body
Foo Bar
=== TEST 10: encoded chars in query strings
--- config
location /main {
echo_subrequest_async GET /sub -q 'foo=a%20b&bar=Bar';
}
location /sub {
echo $arg_foo $arg_bar;
}
--- request
GET /main
--- response_body
a%20b Bar
=== TEST 11: UTF-8 chars in query strings
--- config
location /main {
echo_subrequest_async GET /sub -q 'foo=你好';
}
location /sub {
echo $arg_foo;
}
--- request
GET /main
--- response_body
你好
=== TEST 12: encoded chars in location url
--- config
location /main {
echo_subrequest_async GET /sub%31 -q 'foo=Foo&bar=Bar';
}
location /sub1 {
echo 'sub1';
}
location /sub%31 {
echo 'sub%31';
}
--- request
GET /main
--- response_body
sub%31
=== TEST 13: querystring in url
--- config
location /main {
echo_subrequest_async GET /sub?foo=Foo&bar=Bar;
}
location /sub {
echo $arg_foo $arg_bar;
}
--- request
GET /main
--- response_body
Foo Bar
=== TEST 14: querystring in url *AND* an explicit querystring
--- config
location /main {
echo_subrequest_async GET /sub?foo=Foo&bar=Bar -q blah=Blah;
}
location /sub {
echo $arg_foo $arg_bar $arg_blah;
}
--- request
GET /main
--- response_body
Blah
=== TEST 15: explicit flush in main request
flush won't really flush the buffer...
--- config
location /main_flush {
echo 'pre main';
echo_subrequest_async GET /sub;
echo 'post main';
echo_flush;
}
location /sub {
echo_sleep 0.02;
echo 'sub';
}
--- request
GET /main_flush
--- response_body
pre main
sub
post main
=== TEST 16: POST subrequest with body (with proxy in the middle) and without read body explicitly
--- config
location /main {
echo_subrequest_async POST /proxy -b 'hello, world';
}
location /proxy {
proxy_pass $scheme://127.0.0.1:$server_port/sub;
}
location /sub {
echo "sub method: $echo_request_method.";
# we need to read body explicitly here...or $echo_request_body
# will evaluate to empty ("")
echo "sub body: $echo_request_body.";
}
--- request
GET /main
--- response_body
sub method: POST.
sub body: .
=== TEST 17: POST subrequest with body (with proxy in the middle) and read body explicitly
--- config
location /main {
echo_subrequest_async POST /proxy -b 'hello, world';
}
location /proxy {
proxy_pass $scheme://127.0.0.1:$server_port/sub;
}
location /sub {
echo "sub method: $echo_request_method.";
# we need to read body explicitly here...or $echo_request_body
# will evaluate to empty ("")
echo_read_request_body;
echo "sub body: $echo_request_body.";
}
--- request
GET /main
--- response_body
sub method: POST.
sub body: hello, world.
=== TEST 18: multiple subrequests
--- config
location /multi {
echo_subrequest_async POST '/sub' -q 'foo=Foo' -b 'hi';
echo_subrequest_async PUT '/sub' -q 'bar=Bar' -b 'hello';
}
location /sub {
echo "querystring: $query_string";
echo "method: $echo_request_method";
echo "body: $echo_request_body";
echo "content length: $http_content_length";
echo '///';
}
--- request
GET /multi
--- response_body
querystring: foo=Foo
method: POST
body: hi
content length: 2
///
querystring: bar=Bar
method: PUT
body: hello
content length: 5
///
=== TEST 19: no varaiable inheritance
--- config
location /main {
echo $echo_cacheable_request_uri;
echo_subrequest_async GET /sub;
echo_subrequest_async GET /sub2;
}
location /sub {
echo $echo_cacheable_request_uri;
}
location /sub2 {
echo $echo_cacheable_request_uri;
}
--- request
GET /main
--- response_body
/main
/sub
/sub2
=== TEST 20: unsafe uri
--- config
location /unsafe {
echo_subrequest_async GET '/../foo';
}
--- request
GET /unsafe
--- ignore_response
--- error_log
echo_subrequest_async sees unsafe uri: "/../foo"
--- no_error_log
[error]
[alert]
=== TEST 21: let subrequest to read the main request's request body
--- SKIP
--- config
location /main {
echo_subrequest_async POST /sub;
}
location /sub {
echo_read_request_body;
echo_request_body;
}
--- request
POST /main
hello, body!
--- response_body chomp
hello, body!
=== TEST 22: POST subrequest with file body (relative paths)
--- config
location /main {
echo_subrequest_async POST /sub -f html/blah.txt;
}
location /sub {
echo "sub method: $echo_request_method";
# we don't need to call echo_read_client_body explicitly here
echo_request_body;
}
--- user_files
>>> blah.txt
Hello, world
--- request
GET /main
--- response_body
sub method: POST
Hello, world
=== TEST 23: POST subrequest with file body (absolute paths)
--- config
location /main {
echo_subrequest_async POST /sub -f $TEST_NGINX_HTML_DIR/blah.txt;
}
location /sub {
echo "sub method: $echo_request_method";
# we don't need to call echo_read_client_body explicitly here
echo_request_body;
}
--- user_files
>>> blah.txt
Hello, world!
Haha
--- request
GET /main
--- response_body
sub method: POST
Hello, world!
Haha
=== TEST 24: POST subrequest with file body (file not found)
--- config
location /main {
echo_subrequest_async POST /sub -f html/blah/blah.txt;
}
location /sub {
echo "sub method: $echo_request_method";
# we don't need to call echo_read_client_body explicitly here
echo_request_body;
}
--- user_files
>>> blah.txt
Hello, world
--- request
GET /main
--- ignore_response
--- error_log eval
qr/open\(\) ".*?" failed/
--- no_error_log
[alert]
=== TEST 25: POST subrequest with file body (absolute paths in vars)
--- config
location /main {
set $path $TEST_NGINX_HTML_DIR/blah.txt;
echo_subrequest_async POST /sub -f $path;
}
location /sub {
echo "sub method: $echo_request_method";
# we don't need to call echo_read_client_body explicitly here
echo_request_body;
}
--- user_files
>>> blah.txt
Hello, world!
Haha
--- request
GET /main
--- response_body
sub method: POST
Hello, world!
Haha
=== TEST 26: leading subrequest & echo_before_body
--- config
location /main {
echo_before_body hello;
echo_subrequest_async GET /foo;
}
location /foo {
echo world;
}
--- request
GET /main
--- response_body
hello
world
=== TEST 27: leading subrequest & xss
--- config
location /main {
default_type 'application/json';
xss_get on;
xss_callback_arg c;
echo_subrequest_async GET /foo;
}
location /foo {
echo -n world;
}
--- request
GET /main?c=hi
--- response_body chop
hi(world);
=== TEST 28: multiple leading subrequest & xss
--- config
location /main {
default_type 'application/json';
xss_get on;
xss_callback_arg c;
echo_subrequest_async GET /foo;
echo_subrequest_async GET /bar;
}
location /foo {
echo -n world;
}
location /bar {
echo -n ' people';
}
--- request
GET /main?c=hi
--- response_body chop
hi(world people);
=== TEST 29: sanity (HEAD)
--- config
location /main {
echo_subrequest_async GET /sub;
echo_subrequest_async GET /sub;
}
location /sub {
echo hello;
}
--- request
HEAD /main
--- response_body