2017-11-09 22:57:04 +01:00
|
|
|
'use strict';
|
|
|
|
const common = require('../common.js');
|
2020-03-22 21:53:52 +03:00
|
|
|
const { createHook, AsyncResource } = require('async_hooks');
|
2017-11-09 22:57:04 +01:00
|
|
|
|
|
|
|
const bench = common.createBenchmark(main, {
|
|
|
|
n: [1e6],
|
|
|
|
method: [
|
|
|
|
'trackingEnabled',
|
2020-03-22 21:53:52 +03:00
|
|
|
'trackingEnabledWithDestroyHook',
|
2017-11-09 22:57:04 +01:00
|
|
|
'trackingDisabled',
|
2023-02-01 22:46:09 +01:00
|
|
|
],
|
2017-11-09 22:57:04 +01:00
|
|
|
}, {
|
2023-02-01 22:46:09 +01:00
|
|
|
flags: ['--expose-gc'],
|
2017-11-09 22:57:04 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
function endAfterGC(n) {
|
|
|
|
setImmediate(() => {
|
|
|
|
global.gc();
|
|
|
|
setImmediate(() => {
|
|
|
|
bench.end(n);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-12-30 04:01:23 +01:00
|
|
|
function main({ n, method }) {
|
|
|
|
switch (method) {
|
2017-11-09 22:57:04 +01:00
|
|
|
case 'trackingEnabled':
|
|
|
|
bench.start();
|
2019-11-13 17:47:08 +01:00
|
|
|
for (let i = 0; i < n; i++) {
|
2017-11-09 22:57:04 +01:00
|
|
|
new AsyncResource('foobar');
|
|
|
|
}
|
|
|
|
endAfterGC(n);
|
|
|
|
break;
|
2020-03-22 21:53:52 +03:00
|
|
|
case 'trackingEnabledWithDestroyHook':
|
|
|
|
createHook({ destroy: () => {} }).enable();
|
|
|
|
bench.start();
|
|
|
|
for (let i = 0; i < n; i++) {
|
|
|
|
new AsyncResource('foobar');
|
|
|
|
}
|
|
|
|
endAfterGC(n);
|
|
|
|
break;
|
2017-11-09 22:57:04 +01:00
|
|
|
case 'trackingDisabled':
|
|
|
|
bench.start();
|
2019-11-13 17:47:08 +01:00
|
|
|
for (let i = 0; i < n; i++) {
|
2017-11-09 22:57:04 +01:00
|
|
|
new AsyncResource('foobar', { requireManualDestroy: true });
|
|
|
|
}
|
|
|
|
endAfterGC(n);
|
|
|
|
break;
|
|
|
|
default:
|
2018-01-23 13:19:30 +01:00
|
|
|
throw new Error(`Unsupported method "${method}"`);
|
2017-11-09 22:57:04 +01:00
|
|
|
}
|
|
|
|
}
|