1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
# vim:set ft= ts=4 sw=4 et fdm=marker:
use Test::Nginx::Socket::Lua;
worker_connections(1014);
#master_on();
#workers(4);
#log_level('warn');
no_root_location();
repeat_each(2);
plan tests => repeat_each() * (blocks() * 3);
our $HtmlDir = html_dir;
#$ENV{LUA_CPATH} = "/usr/local/openresty/lualib/?.so;" . $ENV{LUA_CPATH};
no_long_string();
run_tests();
__DATA__
=== TEST 1: pcall works
--- http_config eval
"lua_package_path '$::HtmlDir/?.lua;./?.lua';"
--- config
location = /test {
content_by_lua '
function f(a, b)
if a == 0 and b == 0 then
error("zero error")
end
return 23, "hello", true
end
local res = {pcall(f, 0, 0)}
ngx.say("res len: ", #res)
ngx.say("res: ", unpack(res))
res = {pcall(f, 0)}
ngx.say("res len: ", #res)
ngx.say("res: ", unpack(res))
';
}
--- request
GET /test
--- response_body eval
qr/^res len: 2
res: falsecontent_by_lua\(nginx\.conf:\d+\):4: zero error
res len: 4
res: true23hellotrue
$/s
--- no_error_log
[error]
=== TEST 2: xpcall works
--- http_config eval
"lua_package_path '$::HtmlDir/?.lua;./?.lua';"
--- config
location = /test {
content_by_lua '
function f(a, b)
if a == 0 and b == 0 then
error("zero error")
end
return 23, "hello", true
end
function g()
return f(0, 0)
end
function h()
return f(0)
end
function err(...)
ngx.say("error handler called: ", ...)
return "this is the new err"
end
local res = {xpcall(g, err)}
ngx.say("res len: ", #res)
ngx.say("res: ", unpack(res))
res = {xpcall(h, err)}
ngx.say("res len: ", #res)
ngx.say("res: ", unpack(res))
';
}
--- request
GET /test
--- response_body eval
qr/^error handler called: content_by_lua\(nginx\.conf:\d+\):4: zero error
res len: 2
res: falsethis is the new err
res len: 4
res: true23hellotrue
$/
--- no_error_log
[error]
|