summaryrefslogtreecommitdiff
path: root/benching/test.ts
blob: 81cbc5e6f65e1acec07cda02df2e602a2052b562 (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
import { test } from "../testing/mod.ts";
import { bench, runBenchmarks, BenchmarkTimer } from "./mod.ts";

import "example.ts";

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

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

  bench(async function forAwaitFetchDenolandX10(b: BenchmarkTimer) {
    b.start();
    for (let i: number = 0; i < 10; i++) {
      await fetch("https://deno.land/");
    }
    b.stop();
  });

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

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

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

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