From 07545f1670fa6e0cbd6c4dd13244246265560852 Mon Sep 17 00:00:00 2001 From: Dmitry Volyntsev Date: Tue, 5 Nov 2024 18:19:48 -0800 Subject: [PATCH] Modules: fixed process.env object. Previously, it ignored changes to environment variables introduced with "env" directive. --- nginx/ngx_js.c | 4 ++ nginx/t/js_process.t | 84 ++++++++++++++++++++++++++++ nginx/t/stream_js_process.t | 108 ++++++++++++++++++++++++++++++++++++ 3 files changed, 196 insertions(+) create mode 100644 nginx/t/js_process.t create mode 100644 nginx/t/stream_js_process.t diff --git a/nginx/ngx_js.c b/nginx/ngx_js.c index 1ac53baaa..20c8b2f3d 100644 --- a/nginx/ngx_js.c +++ b/nginx/ngx_js.c @@ -3832,6 +3832,10 @@ ngx_js_init_conf_vm(ngx_conf_t *cf, ngx_js_loc_conf_t *conf, ngx_pool_cleanup_t *cln; ngx_js_named_path_t *import; + if (ngx_set_environment(cf->cycle, NULL) == NULL) { + return NGX_ERROR; + } + if (conf->preload_objects != NGX_CONF_UNSET_PTR) { if (ngx_js_init_preload_vm(cf, (ngx_js_loc_conf_t *)conf) != NGX_OK) { return NGX_ERROR; diff --git a/nginx/t/js_process.t b/nginx/t/js_process.t new file mode 100644 index 000000000..40c1fc1b9 --- /dev/null +++ b/nginx/t/js_process.t @@ -0,0 +1,84 @@ +#!/usr/bin/perl + +# (C) Dmitry Volyntsev +# (C) Nginx, Inc. + +# Tests for http njs module, process object. + +############################################################################### + +use warnings; +use strict; + +use Test::More; +use Socket qw/ CRLF /; + +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/) + ->write_file_expand('nginx.conf', <<'EOF'); + +%%TEST_GLOBALS%% + +daemon off; + +events { +} + +env FOO=bar; +env BAR=baz; + +http { + %%TEST_GLOBALS_HTTP%% + + js_import test.js; + + server { + listen 127.0.0.1:8080; + server_name localhost; + + location /argv { + js_content test.argv; + } + + location /env { + js_content test.env; + } + } +} + +EOF + +$t->write_file('test.js', <= 0}`); + } + + function env(r) { + var e = process.env[r.args.var]; + r.return(200, e ? e : 'undefined'); + } + + export default { argv, env }; + +EOF + +$t->try_run('no njs process object')->plan(4); + +############################################################################### + +like(http_get('/argv'), qr/true true/, 'argv'); +like(http_get('/env?var=FOO'), qr/bar/, 'env FOO'); +like(http_get('/env?var=BAR'), qr/baz/, 'env BAR'); +like(http_get('/env?var=HOME'), qr/undefined/, 'env HOME'); + +############################################################################### diff --git a/nginx/t/stream_js_process.t b/nginx/t/stream_js_process.t new file mode 100644 index 000000000..85becd317 --- /dev/null +++ b/nginx/t/stream_js_process.t @@ -0,0 +1,108 @@ +#!/usr/bin/perl + +# (C) Dmitry Volyntsev +# (C) Nginx, Inc. + +# Tests for stream njs module, process object. + +############################################################################### + +use warnings; +use strict; + +use Test::More; + +BEGIN { use FindBin; chdir($FindBin::Bin); } + +use lib 'lib'; +use Test::Nginx; +use Test::Nginx::Stream qw/ stream /; + +############################################################################### + +select STDERR; $| = 1; +select STDOUT; $| = 1; + +my $t = Test::Nginx->new()->has(qw/stream stream_return/) + ->write_file_expand('nginx.conf', <<'EOF'); + +%%TEST_GLOBALS%% + +daemon off; + +events { +} + +env FOO=bar; +env BAR=baz; + +stream { + %%TEST_GLOBALS_STREAM%% + + js_import test.js; + + js_set $env_foo test.env_foo; + js_set $env_bar test.env_bar; + js_set $env_home test.env_home; + js_set $argv test.argv; + + server { + listen 127.0.0.1:8081; + return $env_foo; + } + + server { + listen 127.0.0.1:8082; + return $env_bar; + } + + server { + listen 127.0.0.1:8083; + return $env_home; + } + + server { + listen 127.0.0.1:8084; + return $argv; + } +} + +EOF + +$t->write_file('test.js', <= 0}`; + } + + export default { env_foo, env_bar, env_home, argv }; + +EOF + +$t->try_run('no njs stream session object')->plan(4); + +############################################################################### + +is(stream('127.0.0.1:' . port(8081))->read(), 'bar', 'env.FOO'); +is(stream('127.0.0.1:' . port(8082))->read(), 'baz', 'env.BAR'); +is(stream('127.0.0.1:' . port(8083))->read(), 'undefined', 'env HOME'); +is(stream('127.0.0.1:' . port(8084))->read(), 'true true', 'argv'); + +###############################################################################