mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 21:19:50 +01:00
c6051a08fa
This pr fixes typos in some parallel tests. PR-URL: https://github.com/nodejs/node/pull/42502 Reviewed-By: Tobias Nießen <tniessen@tnie.de> Reviewed-By: Antoine du Hamel <duhamelantoine1995@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Qingyu Deng <i@ayase-lab.com> Reviewed-By: Mestery <mestery@protonmail.com> Reviewed-By: Darshan Sen <raisinten@gmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
37 lines
921 B
JavaScript
37 lines
921 B
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const async_hooks = require('async_hooks');
|
|
|
|
// Regression test for https://github.com/nodejs/node/issues/30080:
|
|
// An uncaught exception inside a queueMicrotask callback should not lead
|
|
// to multiple after() calls for it.
|
|
|
|
let µtaskId;
|
|
const events = [];
|
|
|
|
async_hooks.createHook({
|
|
init(id, type, triggerId, resource) {
|
|
if (type === 'Microtask') {
|
|
µtaskId = id;
|
|
events.push('init');
|
|
}
|
|
},
|
|
before(id) {
|
|
if (id === µtaskId) events.push('before');
|
|
},
|
|
after(id) {
|
|
if (id === µtaskId) events.push('after');
|
|
},
|
|
destroy(id) {
|
|
if (id === µtaskId) events.push('destroy');
|
|
}
|
|
}).enable();
|
|
|
|
queueMicrotask(() => { throw new Error(); });
|
|
|
|
process.on('uncaughtException', common.mustCall());
|
|
process.on('exit', () => {
|
|
assert.deepStrictEqual(events, ['init', 'after', 'before', 'destroy']);
|
|
});
|