mirror of
https://github.com/nodejs/node.git
synced 2025-05-10 17:57:53 +00:00

Previously even after uncaught exception the worker would continue to execute until there is no more work to do. PR-URL: https://github.com/nodejs/node/pull/21739 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
38 lines
1.0 KiB
JavaScript
38 lines
1.0 KiB
JavaScript
// Flags: --experimental-worker
|
|
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const { Worker } = require('worker_threads');
|
|
|
|
// 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('message', common.mustNotCall());
|
|
w.on('error', common.mustCall((err) => {
|
|
console.log(err.message);
|
|
assert(/^Error: foo$/.test(err));
|
|
}));
|
|
w.on('exit', common.mustCall((code) => {
|
|
// uncaughtException is code 1
|
|
assert.strictEqual(code, 1);
|
|
}));
|
|
} else {
|
|
// cannot use common.mustCall as it cannot catch this
|
|
let called = false;
|
|
process.on('exit', (code) => {
|
|
if (!called) {
|
|
called = true;
|
|
} else {
|
|
assert.fail('Exit callback called twice in worker');
|
|
}
|
|
});
|
|
|
|
setTimeout(() => assert.fail('Timeout executed after uncaughtException'),
|
|
2000);
|
|
|
|
setImmediate(() => {
|
|
throw new Error('foo');
|
|
});
|
|
}
|