From fb7092fb43d5a6e5a29ca5b2f0de6683ee55f3e5 Mon Sep 17 00:00:00 2001 From: Yoshiya Hinosawa Date: Tue, 29 Aug 2023 12:18:25 +0900 Subject: [PATCH] fix(ext/node): fix argv[1] in Worker (#20305) --- cli/tests/unit_node/process_test.ts | 12 ++++++++++++ ext/node/polyfills/process.ts | 2 +- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/cli/tests/unit_node/process_test.ts b/cli/tests/unit_node/process_test.ts index 461afb9f67..bcb7a97679 100644 --- a/cli/tests/unit_node/process_test.ts +++ b/cli/tests/unit_node/process_test.ts @@ -774,3 +774,15 @@ Deno.test({ assertEquals(process.title, "deno"); }, }); + +Deno.test({ + name: "process.argv[1] in Worker", + async fn() { + const worker = new Worker( + `data:text/javascript,import process from "node:process";console.log(process.argv[1]);`, + { type: "module" }, + ); + await delay(10); + worker.terminate(); + }, +}); diff --git a/ext/node/polyfills/process.ts b/ext/node/polyfills/process.ts index c7c22b562d..64a3ef31be 100644 --- a/ext/node/polyfills/process.ts +++ b/ext/node/polyfills/process.ts @@ -873,7 +873,7 @@ internals.__bootstrapNodeProcess = function ( // Overwrites the 2st item with getter. Object.defineProperty(argv, "1", { get: () => { - if (Deno.mainModule.startsWith("file:")) { + if (Deno.mainModule?.startsWith("file:")) { return pathFromURL(new URL(Deno.mainModule)); } else { return join(Deno.cwd(), "$deno$node.js");