mirror of
https://github.com/nodejs/node.git
synced 2025-05-09 15:46:27 +00:00

Fill this commit messsage with more details about the change once all changes are rebased. * Add lib/async_hooks.js * Add JS methods to AsyncWrap for handling the async id stack * Introduce AsyncReset() so that JS functions can reset the id and again trigger the init hooks, allow AsyncWrap::Reset() to be called from JS via asyncReset(). * Add env variable to test additional things in test/common.js PR-URL: https://github.com/nodejs/node/pull/12892 Ref: https://github.com/nodejs/node/pull/11883 Ref: https://github.com/nodejs/node/pull/8531 Reviewed-By: Andreas Madsen <amwebdk@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Sam Roberts <vieuxtech@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Jeremiah Senkpiel <fishrock123@rocketmail.com>
38 lines
818 B
JavaScript
38 lines
818 B
JavaScript
'use strict';
|
|
|
|
const common = require('../common');
|
|
const async_wrap = process.binding('async_wrap');
|
|
const assert = require('assert');
|
|
const async_hooks = require('async_hooks');
|
|
const RUNS = 5;
|
|
let test_id = null;
|
|
let run_cntr = 0;
|
|
let hooks = null;
|
|
|
|
process.on('beforeExit', common.mustCall(() => {
|
|
process.removeAllListeners('uncaughtException');
|
|
hooks.disable();
|
|
assert.strictEqual(test_id, null);
|
|
assert.strictEqual(run_cntr, RUNS);
|
|
}));
|
|
|
|
|
|
hooks = async_hooks.createHook({
|
|
destroy(id) {
|
|
if (id === test_id) {
|
|
run_cntr++;
|
|
test_id = null;
|
|
}
|
|
},
|
|
}).enable();
|
|
|
|
|
|
(function runner(n) {
|
|
assert.strictEqual(test_id, null);
|
|
if (n <= 0) return;
|
|
|
|
test_id = (Math.random() * 1e9) >>> 0;
|
|
async_wrap.addIdToDestroyList(test_id);
|
|
setImmediate(common.mustCall(runner), n - 1);
|
|
})(RUNS);
|