fix: ensure we wait for the inspect to disconnect

This re-orders our node clean up so that we free the environment before
the task runner is cleaned up as node uses the task runner during clean
up.  It also calls WaitForDisconnect() to ensure that inspector agents
are notified that the context is going down.
This commit is contained in:
Samuel Attard 2019-07-23 14:56:22 -07:00 committed by Samuel Attard
parent 60821c8ab0
commit 2132fdfa28
3 changed files with 10 additions and 4 deletions

View file

@ -113,12 +113,15 @@ int NodeMain(int argc, char* argv[]) {
node_debugger.Stop(); node_debugger.Stop();
exit_code = node::EmitExit(env); exit_code = node::EmitExit(env);
env->set_can_call_into_js(false);
node::RunAtExit(env); node::RunAtExit(env);
gin_env.platform()->DrainTasks(env->isolate());
gin_env.platform()->CancelPendingDelayedTasks(env->isolate());
gin_env.platform()->UnregisterIsolate(env->isolate());
v8::Isolate* isolate = env->isolate();
node::FreeEnvironment(env); node::FreeEnvironment(env);
gin_env.platform()->DrainTasks(isolate);
gin_env.platform()->CancelPendingDelayedTasks(isolate);
gin_env.platform()->UnregisterIsolate(isolate);
} }
// According to "src/gin/shell/gin_main.cc": // According to "src/gin/shell/gin_main.cc":

View file

@ -60,8 +60,10 @@ void NodeDebugger::Start() {
void NodeDebugger::Stop() { void NodeDebugger::Stop() {
auto* inspector = env_->inspector_agent(); auto* inspector = env_->inspector_agent();
if (inspector && inspector->IsListening()) if (inspector && inspector->IsListening()) {
inspector->WaitForDisconnect();
inspector->Stop(); inspector->Stop();
}
} }
} // namespace electron } // namespace electron

View file

@ -390,6 +390,7 @@ describe('node feature', () => {
const connection = new WebSocket(socketMatch[0]) const connection = new WebSocket(socketMatch[0])
connection.onopen = () => { connection.onopen = () => {
child.send('plz-quit') child.send('plz-quit')
connection.close()
done() done()
} }
} }