-
Notifications
You must be signed in to change notification settings - Fork 30.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
src: make AtExit callback's per Environment
This commit attempts to address one of the TODOs in #4641 regarding making the AtExit callback's per environment, instead of the current global. bnoordhuis provided a few options for solving this, and one was to use a thread-local which is what this commit attempts to do. PR-URL: #9163 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: bnoordhuis - Ben Noordhuis <info@bnoordhuis.nl>
- Loading branch information
Showing
8 changed files
with
163 additions
and
20 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,112 @@ | ||
#include "node.h" | ||
#include "env.h" | ||
#include "v8.h" | ||
#include "libplatform/libplatform.h" | ||
|
||
#include <string> | ||
#include "gtest/gtest.h" | ||
#include "node_test_fixture.h" | ||
|
||
using node::Environment; | ||
using node::IsolateData; | ||
using node::CreateIsolateData; | ||
using node::FreeIsolateData; | ||
using node::CreateEnvironment; | ||
using node::FreeEnvironment; | ||
using node::AtExit; | ||
using node::RunAtExit; | ||
|
||
static bool called_cb_1 = false; | ||
static bool called_cb_2 = false; | ||
static void at_exit_callback1(void* arg); | ||
static void at_exit_callback2(void* arg); | ||
static std::string cb_1_arg; // NOLINT(runtime/string) | ||
|
||
class EnvironmentTest : public NodeTestFixture { | ||
public: | ||
class Env { | ||
public: | ||
Env(const v8::HandleScope& handle_scope, | ||
v8::Isolate* isolate, | ||
const Argv& argv) { | ||
context_ = v8::Context::New(isolate); | ||
CHECK(!context_.IsEmpty()); | ||
isolate_data_ = CreateIsolateData(isolate, uv_default_loop()); | ||
CHECK_NE(nullptr, isolate_data_); | ||
environment_ = CreateEnvironment(isolate_data_, | ||
context_, | ||
1, *argv, | ||
argv.nr_args(), *argv); | ||
CHECK_NE(nullptr, environment_); | ||
} | ||
|
||
~Env() { | ||
FreeIsolateData(isolate_data_); | ||
FreeEnvironment(environment_); | ||
} | ||
|
||
Environment* operator*() const { | ||
return environment_; | ||
} | ||
|
||
private: | ||
v8::Local<v8::Context> context_; | ||
IsolateData* isolate_data_; | ||
Environment* environment_; | ||
}; | ||
|
||
private: | ||
virtual void TearDown() { | ||
NodeTestFixture::TearDown(); | ||
called_cb_1 = false; | ||
called_cb_2 = false; | ||
} | ||
}; | ||
|
||
TEST_F(EnvironmentTest, AtExitWithEnvironment) { | ||
const v8::HandleScope handle_scope(isolate_); | ||
const Argv argv; | ||
Env env {handle_scope, isolate_, argv}; | ||
|
||
AtExit(*env, at_exit_callback1); | ||
RunAtExit(*env); | ||
EXPECT_TRUE(called_cb_1); | ||
} | ||
|
||
TEST_F(EnvironmentTest, AtExitWithArgument) { | ||
const v8::HandleScope handle_scope(isolate_); | ||
const Argv argv; | ||
Env env {handle_scope, isolate_, argv}; | ||
|
||
std::string arg{"some args"}; | ||
AtExit(*env, at_exit_callback1, static_cast<void*>(&arg)); | ||
RunAtExit(*env); | ||
EXPECT_EQ(arg, cb_1_arg); | ||
} | ||
|
||
TEST_F(EnvironmentTest, MultipleEnvironmentsPerIsolate) { | ||
const v8::HandleScope handle_scope(isolate_); | ||
const Argv argv; | ||
Env env1 {handle_scope, isolate_, argv}; | ||
Env env2 {handle_scope, isolate_, argv}; | ||
|
||
AtExit(*env1, at_exit_callback1); | ||
AtExit(*env2, at_exit_callback2); | ||
RunAtExit(*env1); | ||
EXPECT_TRUE(called_cb_1); | ||
EXPECT_FALSE(called_cb_2); | ||
|
||
RunAtExit(*env2); | ||
EXPECT_TRUE(called_cb_2); | ||
} | ||
|
||
static void at_exit_callback1(void* arg) { | ||
called_cb_1 = true; | ||
if (arg) { | ||
cb_1_arg = *static_cast<std::string*>(arg); | ||
} | ||
} | ||
|
||
static void at_exit_callback2(void* arg) { | ||
called_cb_2 = true; | ||
} |