From 2f9281519ce69bf0d5a4db5d8ea0916e0f8fd779 Mon Sep 17 00:00:00 2001 From: Shelley Vohr Date: Fri, 11 Dec 2020 15:03:41 -0800 Subject: [PATCH] fix: add SafeForTerminationScopes for SIGINT interruptions (#26933) --- patches/node/.patches | 1 + ...ationscopes_for_sigint_interruptions.patch | 39 +++++++++++++++++++ script/node-disabled-tests.json | 1 - 3 files changed, 40 insertions(+), 1 deletion(-) create mode 100644 patches/node/fix_add_safeforterminationscopes_for_sigint_interruptions.patch diff --git a/patches/node/.patches b/patches/node/.patches index 4373e5e52236..816082a380c3 100644 --- a/patches/node/.patches +++ b/patches/node/.patches @@ -30,3 +30,4 @@ fix_add_v8_enable_reverse_jsargs_defines_in_common_gypi.patch fix_allow_preventing_initializeinspector_in_env.patch src_allow_embedders_to_provide_a_custom_pageallocator_to.patch allow_preventing_preparestacktracecallback.patch +fix_add_safeforterminationscopes_for_sigint_interruptions.patch diff --git a/patches/node/fix_add_safeforterminationscopes_for_sigint_interruptions.patch b/patches/node/fix_add_safeforterminationscopes_for_sigint_interruptions.patch new file mode 100644 index 000000000000..b26956c60e20 --- /dev/null +++ b/patches/node/fix_add_safeforterminationscopes_for_sigint_interruptions.patch @@ -0,0 +1,39 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Shelley Vohr +Date: Thu, 10 Dec 2020 14:39:33 -0800 +Subject: fix: add SafeForTerminationScopes for SIGINT interruptions +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +We start Node.js with only_terminate_in_safe_scope set to true becuase +it's set by gin’s IsolateHolder. In those cases, parts of the API that +expect execution termination to happen need to be marked as able to +receive those events. + +Upstreamed at https://github.com/nodejs/node/pull/36344. + +diff --git a/src/module_wrap.cc b/src/module_wrap.cc +index f778b089dc4009912361342077793e7918286de3..9302fa6f68d83717a02b82891466ce12b6af2cfd 100644 +--- a/src/module_wrap.cc ++++ b/src/module_wrap.cc +@@ -350,6 +350,7 @@ void ModuleWrap::Evaluate(const FunctionCallbackInfo& args) { + + ShouldNotAbortOnUncaughtScope no_abort_scope(env); + TryCatchScope try_catch(env); ++ Isolate::SafeForTerminationScope safe_for_termination(env->isolate()); + + bool timed_out = false; + bool received_signal = false; +diff --git a/src/node_contextify.cc b/src/node_contextify.cc +index 848e883a829a9725649d837bff09b30156f4f661..a69570400cd897699b1033102767b3389ff8ef38 100644 +--- a/src/node_contextify.cc ++++ b/src/node_contextify.cc +@@ -933,6 +933,7 @@ bool ContextifyScript::EvalMachine(Environment* env, + return false; + } + TryCatchScope try_catch(env); ++ Isolate::SafeForTerminationScope safe_for_termination(env->isolate()); + ContextifyScript* wrapped_script; + ASSIGN_OR_RETURN_UNWRAP(&wrapped_script, args.Holder(), false); + Local unbound_script = diff --git a/script/node-disabled-tests.json b/script/node-disabled-tests.json index 19d762c56613..77768666e0cc 100644 --- a/script/node-disabled-tests.json +++ b/script/node-disabled-tests.json @@ -146,7 +146,6 @@ "parallel/test-v8-flags", "parallel/test-vm-module-basic", "parallel/test-vm-parse-abort-on-uncaught-exception", - "parallel/test-vm-sigint", "parallel/test-vm-sigint-existing-handler", "parallel/test-vm-timeout", "parallel/test-whatwg-encoding-custom-textdecoder",