mirror of
https://github.com/denoland/deno.git
synced 2024-12-15 11:58:42 -05:00
38555a6a0f
Reland https://github.com/denoland/deno/pull/16777 The codegen is disabled in async ops and when fallback to slow call is possible (return type is a Result) to avoid hitting this V8 bug: https://github.com/denoland/deno/issues/17159
21 lines
718 B
JavaScript
21 lines
718 B
JavaScript
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
|
|
// Note: when benchmarking across different Deno version, make sure to clear
|
|
// the DENO_DIR cache.
|
|
let [total, count] = typeof Deno !== "undefined" ? Deno.args : [];
|
|
|
|
total = total ? parseInt(total, 0) : 50;
|
|
count = count ? parseInt(count, 10) : 1000000;
|
|
|
|
function bench(fun) {
|
|
const start = Date.now();
|
|
for (let i = 0; i < count; i++) fun(i);
|
|
const elapsed = Date.now() - start;
|
|
const rate = Math.floor(count / (elapsed / 1000));
|
|
console.log(`time ${elapsed} ms rate ${rate}`);
|
|
if (--total) queueMicrotask(() => bench(fun));
|
|
}
|
|
|
|
localStorage.clear();
|
|
localStorage.setItem("foo", "bar");
|
|
bench(() => localStorage.getItem("foo"));
|