2020-01-02 23:09:20 +08:00
|
|
|
'use strict';
|
|
|
|
const common = require('../common.js');
|
|
|
|
const { createHook } = require('async_hooks');
|
|
|
|
|
2020-04-16 15:23:57 -07:00
|
|
|
let hook;
|
|
|
|
const tests = {
|
|
|
|
disabled() {
|
|
|
|
hook = createHook({
|
|
|
|
promiseResolve() {}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
enabled() {
|
|
|
|
hook = createHook({
|
|
|
|
promiseResolve() {}
|
|
|
|
}).enable();
|
|
|
|
},
|
|
|
|
enabledWithDestroy() {
|
|
|
|
hook = createHook({
|
|
|
|
promiseResolve() {},
|
|
|
|
destroy() {}
|
|
|
|
}).enable();
|
2020-07-25 20:37:30 +03:00
|
|
|
},
|
|
|
|
enabledWithInitOnly() {
|
|
|
|
hook = createHook({
|
|
|
|
init() {}
|
|
|
|
}).enable();
|
2020-04-16 15:23:57 -07:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2020-01-02 23:09:20 +08:00
|
|
|
const bench = common.createBenchmark(main, {
|
|
|
|
n: [1e6],
|
|
|
|
asyncHooks: [
|
|
|
|
'enabled',
|
2020-04-16 15:23:57 -07:00
|
|
|
'enabledWithDestroy',
|
2020-07-25 20:37:30 +03:00
|
|
|
'enabledWithInitOnly',
|
2020-01-02 23:09:20 +08:00
|
|
|
'disabled',
|
|
|
|
]
|
|
|
|
});
|
|
|
|
|
|
|
|
async function run(n) {
|
|
|
|
for (let i = 0; i < n; i++) {
|
|
|
|
await new Promise((resolve) => resolve())
|
|
|
|
.then(() => { throw new Error('foobar'); })
|
|
|
|
.catch((e) => e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function main({ n, asyncHooks }) {
|
2020-04-16 15:23:57 -07:00
|
|
|
if (hook) hook.disable();
|
|
|
|
tests[asyncHooks]();
|
2020-01-02 23:09:20 +08:00
|
|
|
bench.start();
|
|
|
|
run(n).then(() => {
|
|
|
|
bench.end(n);
|
|
|
|
});
|
|
|
|
}
|