aboutsummaryrefslogtreecommitdiff
path: root/bench/snippets/callbacks-overhead.mjs
diff options
context:
space:
mode:
authorGravatar evan <github@evan.lol> 2022-07-12 04:40:12 -0400
committerGravatar GitHub <noreply@github.com> 2022-07-12 01:40:12 -0700
commita9e4ff2029a769737982fcf7e0b7d76d35cf35e4 (patch)
tree497832408d926e2bed779fcec4ba655624a29792 /bench/snippets/callbacks-overhead.mjs
parent7eea306b0ff46a27f134809a9b3c12bf4b38fa7e (diff)
downloadbun-a9e4ff2029a769737982fcf7e0b7d76d35cf35e4.tar.gz
bun-a9e4ff2029a769737982fcf7e0b7d76d35cf35e4.tar.zst
bun-a9e4ff2029a769737982fcf7e0b7d76d35cf35e4.zip
cleanup benchmarks folder (#587)
* cleanup benchmarks * run prettier
Diffstat (limited to 'bench/snippets/callbacks-overhead.mjs')
-rw-r--r--bench/snippets/callbacks-overhead.mjs78
1 files changed, 78 insertions, 0 deletions
diff --git a/bench/snippets/callbacks-overhead.mjs b/bench/snippets/callbacks-overhead.mjs
new file mode 100644
index 000000000..65171145c
--- /dev/null
+++ b/bench/snippets/callbacks-overhead.mjs
@@ -0,0 +1,78 @@
+const iterations = 1_000;
+
+export var report = {
+ async: 0,
+ callback: 0,
+ sync: 0,
+ then: 0,
+};
+
+const tests = {
+ callback(n, cb) {
+ if (n === iterations) return cb();
+ tests.callback(1 + n, () => cb());
+ },
+
+ sync(n) {
+ if (n === iterations) return;
+
+ tests.sync(1 + n);
+ },
+
+ async async(n) {
+ if (n === iterations) return;
+
+ await tests.async(1 + n);
+ },
+
+ then(n) {
+ if (n === iterations) return;
+ return Promise.resolve(1 + n).then(tests.then);
+ },
+};
+
+async function test(log) {
+ {
+ const a = performance.now();
+ await tests.async(0);
+ if (log)
+ console.log(
+ `async/await: ${(report.async = (performance.now() - a).toFixed(4))}ms`
+ );
+ }
+
+ {
+ const a = performance.now();
+ tests.callback(0, function () {
+ if (log)
+ console.log(
+ `callback: ${(report.callback = (performance.now() - a).toFixed(
+ 4
+ ))}ms`
+ );
+ });
+ }
+
+ {
+ const a = performance.now();
+ await tests.then(0);
+ if (log)
+ console.log(
+ `then: ${(report.then = (performance.now() - a).toFixed(4))}ms`
+ );
+ }
+
+ {
+ const a = performance.now();
+ tests.sync(0);
+ if (log)
+ console.log(
+ `sync: ${(report.sync = (performance.now() - a).toFixed(4))}ms`
+ );
+ }
+}
+
+let warmup = 10;
+while (warmup--) await test();
+
+await test(true);