summaryrefslogtreecommitdiff
path: root/cli/bench/async_ops_deferred.js
diff options
context:
space:
mode:
Diffstat (limited to 'cli/bench/async_ops_deferred.js')
-rw-r--r--cli/bench/async_ops_deferred.js20
1 files changed, 20 insertions, 0 deletions
diff --git a/cli/bench/async_ops_deferred.js b/cli/bench/async_ops_deferred.js
new file mode 100644
index 000000000..7a816cf95
--- /dev/null
+++ b/cli/bench/async_ops_deferred.js
@@ -0,0 +1,20 @@
+// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
+const queueMicrotask = globalThis.queueMicrotask || process.nextTick;
+let [total, count] = typeof Deno !== "undefined"
+ ? Deno.args
+ : [process.argv[2], process.argv[3]];
+
+total = total ? parseInt(total, 0) : 50;
+count = count ? parseInt(count, 10) : 1000000;
+
+async function bench(fun) {
+ const start = Date.now();
+ for (let i = 0; i < count; i++) await fun();
+ const elapsed = Date.now() - start;
+ const rate = Math.floor(count / (elapsed / 1000));
+ console.log(`time ${elapsed} ms rate ${rate}`);
+ if (--total) queueMicrotask(() => bench(fun));
+}
+
+const core = Deno[Deno.internal].core;
+bench(() => core.opAsync("op_void_async_deferred"));