summaryrefslogtreecommitdiff
path: root/std/testing/bench_test.ts
blob: 8af2f0d6db39f31e2559ae074aab92be2d3bfad2 (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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
import { test, runIfMain } from "./mod.ts";
import { bench, runBenchmarks } from "./bench.ts";

import "./bench_example.ts";

test(async function benching(): Promise<void> {
  bench(function forIncrementX1e9(b): void {
    b.start();
    for (let i = 0; i < 1e9; i++);
    b.stop();
  });

  bench(function forDecrementX1e9(b): void {
    b.start();
    for (let i = 1e9; i > 0; i--);
    b.stop();
  });

  bench(async function forAwaitFetchDenolandX10(b): Promise<void> {
    b.start();
    for (let i = 0; i < 10; i++) {
      const r = await fetch("https://deno.land/");
      await r.text();
    }
    b.stop();
  });

  bench(async function promiseAllFetchDenolandX10(b): Promise<void> {
    const urls = new Array(10).fill("https://deno.land/");
    b.start();
    await Promise.all(
      urls.map(
        async (denoland: string): Promise<void> => {
          const r = await fetch(denoland);
          await r.text();
        }
      )
    );
    b.stop();
  });

  bench({
    name: "runs100ForIncrementX1e6",
    runs: 100,
    func(b): void {
      b.start();
      for (let i = 0; i < 1e6; i++);
      b.stop();
    }
  });

  bench(function throwing(b): void {
    b.start();
    // Throws bc the timer's stop method is never called
  });

  await runBenchmarks({ skip: /throw/ });
});

runIfMain(import.meta);