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 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207
|
use Test::Nginx::Socket::Lua;
repeat_each(2);
plan tests => repeat_each() * (blocks() * 3);
$ENV{TEST_NGINX_HTML_DIR} ||= html_dir();
my $html_dir = $ENV{TEST_NGINX_HTML_DIR};
my $http_config = <<_EOC_;
init_by_lua_block {
function set_up_ngx_tmp_conf(conf)
if conf == nil then
conf = [[
# to prevent the test process from overwriting the
# original pid file
pid logs/test_nginx.pid;
events {
worker_connections 64;
}
http {
init_by_lua_block {
ngx.log(ngx.ERR, "run init_by_lua")
}
}
]]
end
assert(os.execute("mkdir -p $html_dir/logs"))
local conf_file = "$html_dir/nginx.conf"
local f, err = io.open(conf_file, "w")
if not f then
ngx.log(ngx.ERR, err)
return
end
assert(f:write(conf))
f:close()
return conf_file
end
function get_ngx_bin_path()
local ffi = require "ffi"
ffi.cdef[[char **ngx_argv;]]
return ffi.string(ffi.C.ngx_argv[0])
end
}
_EOC_
add_block_preprocessor(sub {
my $block = shift;
if (!defined $block->http_config) {
$block->set_value("http_config", $http_config);
}
if (!defined $block->request) {
$block->set_value("request", "GET /t");
}
});
env_to_nginx("PATH");
log_level("warn");
no_long_string();
run_tests();
__DATA__
=== TEST 1: ensure init_by_lua* is not run in signaller process
--- config
location = /t {
content_by_lua_block {
local conf_file = set_up_ngx_tmp_conf()
local nginx = get_ngx_bin_path()
local cmd = nginx .. " -p $TEST_NGINX_HTML_DIR -c " .. conf_file .. " -s reopen"
local p, err = io.popen(cmd)
if not p then
ngx.log(ngx.ERR, err)
return
end
local out, err = p:read("*a")
if not out then
ngx.log(ngx.ERR, err)
else
ngx.log(ngx.WARN, out)
end
p:close()
collectgarbage("collect")
}
}
--- error_log
failed (2: No such file or directory)
--- no_error_log eval
qr/\[error\] .*? init_by_lua:\d+: run init_by_lua/
=== TEST 2: init_by_lua* does not run when testing Nginx configuration
--- config
location = /t {
content_by_lua_block {
local conf_file = set_up_ngx_tmp_conf()
local nginx = get_ngx_bin_path()
local cmd = nginx .. " -p $TEST_NGINX_HTML_DIR -c " .. conf_file .. " -t"
local p, err = io.popen(cmd)
if not p then
ngx.log(ngx.ERR, err)
return
end
local out, err = p:read("*a")
if not out then
ngx.log(ngx.ERR, err)
else
ngx.log(ngx.WARN, out)
end
p:close()
local cmd = nginx .. " -p $TEST_NGINX_HTML_DIR -c " .. conf_file .. " -T"
local p, err = io.popen(cmd)
if not p then
ngx.log(ngx.ERR, err)
return
end
local out, err = p:read("*a")
if not out then
ngx.log(ngx.ERR, err)
else
ngx.log(ngx.WARN, out)
end
p:close()
collectgarbage("collect")
}
}
--- error_log
test is successful
--- no_error_log eval
qr/\[error\] .*? init_by_lua:\d+: run init_by_lua/
=== TEST 3: init_by_lua* does not run when testing Nginx configuration which contains 'lua_shared_dict' (GitHub #1462)
--- config
location = /t {
content_by_lua_block {
local conf = [[
pid logs/test_nginx.pid;
events {
worker_connections 64;
}
http {
lua_shared_dict test 64k;
init_by_lua_block {
ngx.log(ngx.ERR, "run init_by_lua with lua_shared_dict")
}
}
]]
local conf_file = set_up_ngx_tmp_conf(conf)
local nginx = get_ngx_bin_path()
local cmd = nginx .. " -p $TEST_NGINX_HTML_DIR -c " .. conf_file .. " -t"
local p, err = io.popen(cmd)
if not p then
ngx.log(ngx.ERR, err)
return
end
local out, err = p:read("*a")
if not out then
ngx.log(ngx.ERR, err)
else
ngx.log(ngx.WARN, out)
end
p:close()
local cmd = nginx .. " -p $TEST_NGINX_HTML_DIR -c " .. conf_file .. " -T"
local p, err = io.popen(cmd)
if not p then
ngx.log(ngx.ERR, err)
return
end
local out, err = p:read("*a")
if not out then
ngx.log(ngx.ERR, err)
else
ngx.log(ngx.WARN, out)
end
p:close()
collectgarbage("collect")
}
}
--- error_log
test is successful
--- no_error_log eval
qr/\[error\] .*? init_by_lua:\d+: run init_by_lua with lua_shared_dict/
|