summaryrefslogtreecommitdiff
path: root/std/testing/bench_example.ts
diff options
context:
space:
mode:
authorRyan Dahl <ry@tinyclouds.org>2019-10-09 17:18:08 -0400
committerRyan Dahl <ry@tinyclouds.org>2019-10-09 17:18:08 -0400
commit28293acd9c12a94f5d769706291032e844c7b92b (patch)
tree1fec6a3cd8d7c9e8bc9b1486f5c8438eb906a595 /std/testing/bench_example.ts
parent5c6835efd82c298df99ce71c4a36ca23515333a3 (diff)
parent151ce0266eb4de2c8fc600c81c192a5f791b6169 (diff)
Merge branch 'std_modified' into merge_std3
Diffstat (limited to 'std/testing/bench_example.ts')
-rw-r--r--std/testing/bench_example.ts29
1 files changed, 29 insertions, 0 deletions
diff --git a/std/testing/bench_example.ts b/std/testing/bench_example.ts
new file mode 100644
index 000000000..d27fb97e8
--- /dev/null
+++ b/std/testing/bench_example.ts
@@ -0,0 +1,29 @@
+// https://deno.land/std/testing/bench.ts
+import { BenchmarkTimer, bench, runIfMain } from "./bench.ts";
+
+// Basic
+bench(function forIncrementX1e9(b: BenchmarkTimer): void {
+ b.start();
+ for (let i = 0; i < 1e9; i++);
+ b.stop();
+});
+
+// Reporting average measured time for $runs runs of func
+bench({
+ name: "runs100ForIncrementX1e6",
+ runs: 100,
+ func(b): void {
+ b.start();
+ for (let i = 0; i < 1e6; i++);
+ b.stop();
+ }
+});
+
+// Itsabug
+bench(function throwing(b): void {
+ b.start();
+ // Throws bc the timer's stop method is never called
+});
+
+// Bench control
+runIfMain(import.meta, { skip: /throw/ });