summaryrefslogtreecommitdiff
path: root/std/testing/bench_example.ts
blob: 401516cca8de1949c43d643bd45438d1f20dc522 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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/ });