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
|
# vim:set ft= ts=4 sw=4 et fdm=marker:
our $SkipReason;
BEGIN {
if ($ENV{TEST_NGINX_CHECK_LEAK}) {
$SkipReason = "unavailable for the hup tests";
} elsif (defined $ENV{TEST_NGINX_USE_HTTP3}) {
#os.execute("kill -HUP " .. pid)
$SkipReason = "send HUP relaod signal by self make two workers with same id";
} else {
$ENV{TEST_NGINX_USE_HUP} = 1;
undef $ENV{TEST_NGINX_USE_STAP};
}
}
use Test::Nginx::Socket::Lua $SkipReason ? (skip_all => $SkipReason) : ();
repeat_each(2);
plan tests => repeat_each() * (blocks() * 8);
#no_diff();
no_long_string();
worker_connections(1024);
run_tests();
__DATA__
=== TEST 1: exiting
--- config
location /t {
set $port $TEST_NGINX_SERVER_PORT;
content_by_lua_block {
local pidfile = ngx.config.prefix() .. "/logs/nginx.pid"
local f, err = io.open(pidfile, "r")
if not f then
ngx.say("failed to open nginx.pid: ", err)
return
end
local pid = f:read()
-- ngx.say("master pid: [", pid, "]")
f:close()
local i = 0
local port = ngx.var.port
local function f(premature)
print("timer prematurely expired: ", premature)
local sock = ngx.socket.tcp()
local ok, err = sock:connect("127.0.0.1", port)
if not ok then
print("failed to connect: ", err)
return
end
local ok, err = sock:setkeepalive()
if not ok then
print("failed to setkeepalive: ", err)
return
end
print("setkeepalive successfully")
end
local ok, err = ngx.timer.at(3, f)
if not ok then
ngx.say("failed to set timer: ", err)
return
end
ngx.say("registered timer")
os.execute("kill -HUP " .. pid)
}
}
--- request
GET /t
--- response_body
registered timer
--- wait: 0.3
--- no_error_log
[error]
[alert]
[crit]
--- error_log
timer prematurely expired: true
setkeepalive successfully
lua tcp socket set keepalive while process exiting, closing connection
|