test: add Worker + uncaughtException + process.exit() test
PR-URL: https://github.com/nodejs/node/pull/28259 Reviewed-By: Gireesh Punathil <gpunathi@in.ibm.com> Reviewed-By: Rich Trott <rtrott@gmail.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Franziska Hinkelmann <franziska.hinkelmann@gmail.com>
This commit is contained in:
parent
a33c3c6d33
commit
7146ddd8a0
23
test/parallel/test-worker-exit-from-uncaught-exception.js
Normal file
23
test/parallel/test-worker-exit-from-uncaught-exception.js
Normal file
@ -0,0 +1,23 @@
|
||||
'use strict';
|
||||
const common = require('../common');
|
||||
const assert = require('assert');
|
||||
const { Worker } = require('worker_threads');
|
||||
|
||||
// Check that `process.exit()` can be called inside a Worker from an uncaught
|
||||
// exception handler.
|
||||
|
||||
// Do not use isMainThread so that this test itself can be run inside a Worker.
|
||||
if (!process.env.HAS_STARTED_WORKER) {
|
||||
process.env.HAS_STARTED_WORKER = 1;
|
||||
const w = new Worker(__filename);
|
||||
w.on('exit', common.mustCall((code) => {
|
||||
assert.strictEqual(code, 42);
|
||||
}));
|
||||
return;
|
||||
}
|
||||
|
||||
process.on('uncaughtException', () => {
|
||||
process.exit(42);
|
||||
});
|
||||
|
||||
throw new Error();
|
Loading…
x
Reference in New Issue
Block a user