node/test/parallel/test-inspector-exit-worker-in-wait-for-connection2.js
Daeyeon Jeong e1b80a5fb3
src: fix Worker termination when '--inspect-brk' is passed
Signed-off-by: Daeyeon Jeong <daeyeon.dev@gmail.com>
PR-URL: https://github.com/nodejs/node/pull/53724
Fixes: https://github.com/nodejs/node/issues/53648
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Kohei Ueno <kohei.ueno119@gmail.com>
2024-07-06 15:49:50 +00:00

48 lines
1.2 KiB
JavaScript

'use strict';
const common = require('../common');
common.skipIfInspectorDisabled();
const { workerData, Worker } = require('node:worker_threads');
if (!workerData) {
common.skipIfWorker();
}
const assert = require('node:assert');
let TIMEOUT = common.platformTimeout(5000);
if (common.isWindows) {
// Refs: https://github.com/nodejs/build/issues/3014
TIMEOUT = common.platformTimeout(15000);
}
// Refs: https://github.com/nodejs/node/issues/53648
(async () => {
if (!workerData) {
// worker.terminate() should terminate the worker created with execArgv:
// ["--inspect-brk"].
{
const worker = new Worker(__filename, {
execArgv: ['--inspect-brk=0'],
workerData: {},
});
await new Promise((r) => setTimeout(r, TIMEOUT));
worker.on('exit', common.mustCall());
await worker.terminate();
}
// process.exit() should kill the process.
{
new Worker(__filename, {
execArgv: ['--inspect-brk=0'],
workerData: {},
});
await new Promise((r) => setTimeout(r, TIMEOUT));
process.on('exit', (status) => assert.strictEqual(status, 0));
setImmediate(() => process.exit());
}
} else {
console.log('Worker running!');
}
})().then(common.mustCall());