mirror of
https://github.com/nodejs/node.git
synced 2025-05-02 03:31:35 +00:00

PR-URL: https://github.com/nodejs/node/pull/21899 Reviewed-By: Ali Ijaz Sheikh <ofrobots@google.com>
76 lines
1.5 KiB
JavaScript
76 lines
1.5 KiB
JavaScript
'use strict';
|
|
|
|
const common = require('../common.js');
|
|
|
|
const bench = common.createBenchmark(main, {
|
|
n: [100000],
|
|
method: ['trace', 'emit', 'isTraceCategoryEnabled', 'categoryGroupEnabled']
|
|
}, {
|
|
flags: ['--expose-internals', '--trace-event-categories', 'foo']
|
|
});
|
|
|
|
const {
|
|
trace,
|
|
isTraceCategoryEnabled,
|
|
emit,
|
|
categoryGroupEnabled
|
|
} = process.binding('trace_events');
|
|
|
|
const {
|
|
TRACE_EVENT_PHASE_NESTABLE_ASYNC_BEGIN: kBeforeEvent
|
|
} = process.binding('constants').trace;
|
|
|
|
function doEmit(n) {
|
|
bench.start();
|
|
for (var i = 0; i < n; i++) {
|
|
emit(kBeforeEvent, 'foo', 'test', 0, 'arg1', 1);
|
|
}
|
|
bench.end(n);
|
|
}
|
|
|
|
function doTrace(n) {
|
|
bench.start();
|
|
for (var i = 0; i < n; i++) {
|
|
trace(kBeforeEvent, 'foo', 'test', 0, 'test');
|
|
}
|
|
bench.end(n);
|
|
}
|
|
|
|
function doIsTraceCategoryEnabled(n) {
|
|
bench.start();
|
|
for (var i = 0; i < n; i++) {
|
|
isTraceCategoryEnabled('foo');
|
|
isTraceCategoryEnabled('bar');
|
|
}
|
|
bench.end(n);
|
|
}
|
|
|
|
function doCategoryGroupEnabled(n) {
|
|
bench.start();
|
|
for (var i = 0; i < n; i++) {
|
|
categoryGroupEnabled('foo');
|
|
categoryGroupEnabled('bar');
|
|
}
|
|
bench.end(n);
|
|
}
|
|
|
|
function main({ n, method }) {
|
|
switch (method) {
|
|
case '':
|
|
case 'trace':
|
|
doTrace(n);
|
|
break;
|
|
case 'emit':
|
|
doEmit(n);
|
|
break;
|
|
case 'isTraceCategoryEnabled':
|
|
doIsTraceCategoryEnabled(n);
|
|
break;
|
|
case 'categoryGroupEnabled':
|
|
doCategoryGroupEnabled(n);
|
|
break;
|
|
default:
|
|
throw new Error(`Unexpected method "${method}"`);
|
|
}
|
|
}
|