aboutsummaryrefslogtreecommitdiff
path: root/deps/node/benchmark/async_hooks
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2019-04-03 15:43:32 +0200
committerFlorian Dold <florian.dold@gmail.com>2019-04-03 15:45:57 +0200
commit71e285b94c7edaa43aa8115965cf5a36b8e0f80a (patch)
tree7d4aa9d0d5aff686b106cd5da72ba77960c4af43 /deps/node/benchmark/async_hooks
parent7dadf9356b4f3f4137ce982ea5bb960283116e9a (diff)
downloadakono-71e285b94c7edaa43aa8115965cf5a36b8e0f80a.tar.gz
akono-71e285b94c7edaa43aa8115965cf5a36b8e0f80a.tar.bz2
akono-71e285b94c7edaa43aa8115965cf5a36b8e0f80a.zip
Node.js v11.13.0
Diffstat (limited to 'deps/node/benchmark/async_hooks')
-rw-r--r--deps/node/benchmark/async_hooks/gc-tracking.js44
1 files changed, 44 insertions, 0 deletions
diff --git a/deps/node/benchmark/async_hooks/gc-tracking.js b/deps/node/benchmark/async_hooks/gc-tracking.js
new file mode 100644
index 00000000..d74b2bac
--- /dev/null
+++ b/deps/node/benchmark/async_hooks/gc-tracking.js
@@ -0,0 +1,44 @@
+'use strict';
+const common = require('../common.js');
+const { AsyncResource } = require('async_hooks');
+
+const bench = common.createBenchmark(main, {
+ n: [1e6],
+ method: [
+ 'trackingEnabled',
+ 'trackingDisabled',
+ ]
+}, {
+ flags: ['--expose-gc']
+});
+
+function endAfterGC(n) {
+ setImmediate(() => {
+ global.gc();
+ setImmediate(() => {
+ bench.end(n);
+ });
+ });
+}
+
+function main({ n, method }) {
+ var i;
+ switch (method) {
+ case 'trackingEnabled':
+ bench.start();
+ for (i = 0; i < n; i++) {
+ new AsyncResource('foobar');
+ }
+ endAfterGC(n);
+ break;
+ case 'trackingDisabled':
+ bench.start();
+ for (i = 0; i < n; i++) {
+ new AsyncResource('foobar', { requireManualDestroy: true });
+ }
+ endAfterGC(n);
+ break;
+ default:
+ throw new Error(`Unsupported method "${method}"`);
+ }
+}