From 4cfdafb72b0c28e2a1bf3afd74266f03fa0f9c98 Mon Sep 17 00:00:00 2001 From: Joyee Cheung Date: Wed, 12 Jul 2023 19:12:00 +0200 Subject: [PATCH] src: generate default snapshot with --predictable To improve determinism of snapshot generation, add --predictable to the V8 flags used to initialize a process launched to generate snapshot. Also add a kGeneratePredictableSnapshot flag to ProcessInitializationFlags for this and moves the configuration of these flags into node::InitializeOncePerProcess() so that it can be shared by embedders. --- src/node.cc | 6 ++++++ src/node.h | 2 ++ tools/snapshot/node_mksnapshot.cc | 5 ++--- 3 files changed, 10 insertions(+), 3 deletions(-) diff --git a/src/node.cc b/src/node.cc index 17f3829d743941..6a7ccd80be10ca 100644 --- a/src/node.cc +++ b/src/node.cc @@ -842,6 +842,12 @@ static ExitCode InitializeNodeWithArgsInternal( // default value. V8::SetFlagsFromString("--rehash-snapshot"); + if (!!(flags & ProcessInitializationFlags::kGeneratePredictableSnapshot) || + per_process::cli_options->per_isolate->build_snapshot) { + v8::V8::SetFlagsFromString("--predictable"); + v8::V8::SetFlagsFromString("--random_seed=42"); + } + HandleEnvOptions(per_process::cli_options->per_isolate->per_env); std::string node_options; diff --git a/src/node.h b/src/node.h index ca01c42e8af484..f2740116a4710b 100644 --- a/src/node.h +++ b/src/node.h @@ -265,6 +265,8 @@ enum Flags : uint32_t { // cppgc::InitializeProcess() before creating a Node.js environment // and call cppgc::ShutdownProcess() before process shutdown. kNoInitializeCppgc = 1 << 13, + // Initialize the process for predictable snapshot generation. + kGeneratePredictableSnapshot = 1 << 14, // Emulate the behavior of InitializeNodeWithArgs() when passing // a flags argument to the InitializeOncePerProcess() replacement diff --git a/tools/snapshot/node_mksnapshot.cc b/tools/snapshot/node_mksnapshot.cc index a9df251700ea06..841a8ca743bcaa 100644 --- a/tools/snapshot/node_mksnapshot.cc +++ b/tools/snapshot/node_mksnapshot.cc @@ -50,8 +50,6 @@ int main(int argc, char* argv[]) { setvbuf(stderr, nullptr, _IONBF, 0); #endif // _WIN32 - v8::V8::SetFlagsFromString("--random_seed=42"); - v8::V8::SetFlagsFromString("--harmony-import-assertions"); return BuildSnapshot(argc, argv); } @@ -65,7 +63,8 @@ int BuildSnapshot(int argc, char* argv[]) { std::unique_ptr result = node::InitializeOncePerProcess( - std::vector(argv, argv + argc)); + std::vector(argv, argv + argc), + node::ProcessInitializationFlags::kGeneratePredictableSnapshot); CHECK(!result->early_return()); CHECK_EQ(result->exit_code(), 0);