Skip to content
Permalink
Browse files

benchmark: add benchmark on async_hooks enabled http server

PR-URL: #31100
Refs: nodejs/diagnostics#124
Reviewed-By: Rich Trott <rtrott@gmail.com>
Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
Reviewed-By: James M Snell <jasnell@gmail.com>
  • Loading branch information
legendecas authored and BridgeAR committed Dec 26, 2019
1 parent 5bf2772 commit 827d3fea0e17ba1db642df43fb92b7d6f51e8d4a
Showing with 42 additions and 0 deletions.
  1. +40 −0 benchmark/async_hooks/http-server.js
  2. +2 −0 test/benchmark/test-benchmark-async-hooks.js
@@ -0,0 +1,40 @@
'use strict';
const common = require('../common.js');

const bench = common.createBenchmark(main, {
asyncHooks: ['init', 'before', 'after', 'all', 'disabled', 'none'],
connections: [50, 500]
});

function main({ asyncHooks, connections }) {
if (asyncHooks !== 'none') {
let hooks = {
init() {},
before() {},
after() {},
destroy() {},
promiseResolve() {}
};
if (asyncHooks !== 'all' || asyncHooks !== 'disabled') {
hooks = {
[asyncHooks]: () => {}
};
}
const hook = require('async_hooks').createHook(hooks);
if (asyncHooks !== 'disabled') {
hook.enable();
}
}
const server = require('../fixtures/simple-http-server.js')
.listen(common.PORT)
.on('listening', () => {
const path = '/buffer/4/4/normal/1';

bench.http({
connections,
path,
}, () => {
server.close();
});
});
}
@@ -12,6 +12,8 @@ const runBenchmark = require('../common/benchmark');

runBenchmark('async_hooks',
[
'asyncHooks=all',
'connections=50',
'method=trackingDisabled',
'n=10'
],

0 comments on commit 827d3fe

Please sign in to comment.
You can’t perform that action at this time.