diff options
| author | Divy Srivastava <dj.srivastava23@gmail.com> | 2023-03-03 19:04:10 +0530 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-03-03 19:04:10 +0530 |
| commit | 38555a6a0fe9a7235776afe0ebfb2a24dc518391 (patch) | |
| tree | ef9506c500451e5f2ef4ae5b70eda85c7147a25e /cli/bench | |
| parent | 64503fabd81e38c58d44d23ae94f5b87a384b86e (diff) | |
feat(ops): reland fast zero copy string arguments (#17996)
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
Diffstat (limited to 'cli/bench')
| -rw-r--r-- | cli/bench/console.js | 5 | ||||
| -rw-r--r-- | cli/bench/encode_into.js | 5 | ||||
| -rw-r--r-- | cli/bench/webstorage.js | 21 |
3 files changed, 23 insertions, 8 deletions
diff --git a/cli/bench/console.js b/cli/bench/console.js index f31d77d25..5f67c0a4b 100644 --- a/cli/bench/console.js +++ b/cli/bench/console.js @@ -1,8 +1,3 @@ // Copyright 2018-2023 the Deno authors. All rights reserved. MIT license. const count = 100000; - -const start = Date.now(); for (let i = 0; i < count; i++) console.log("Hello World"); -const elapsed = Date.now() - start; -const rate = Math.floor(count / (elapsed / 1000)); -console.log(`time ${elapsed} ms rate ${rate}`); diff --git a/cli/bench/encode_into.js b/cli/bench/encode_into.js index 0767ebfce..aae39080a 100644 --- a/cli/bench/encode_into.js +++ b/cli/bench/encode_into.js @@ -1,11 +1,10 @@ // 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; +count = count ? parseInt(count, 10) : 10000000; function bench(fun) { const start = Date.now(); @@ -13,7 +12,7 @@ function bench(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)); + if (--total) bench(fun); } const encoder = new TextEncoder(); diff --git a/cli/bench/webstorage.js b/cli/bench/webstorage.js new file mode 100644 index 000000000..ceebc5e35 --- /dev/null +++ b/cli/bench/webstorage.js @@ -0,0 +1,21 @@ +// 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")); |
