summaryrefslogtreecommitdiff
path: root/cli/tests/unit/performance_test.ts
blob: 3c98e4e4062b2b2fe53ada4bbece9a396f07efec (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
61
62
63
64
65
66
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
import {
  unitTest,
  assert,
  assertEquals,
  createResolvable,
} from "./test_util.ts";

unitTest({ perms: { hrtime: false } }, async function performanceNow(): Promise<
  void
> {
  const resolvable = createResolvable();
  const start = performance.now();
  setTimeout((): void => {
    const end = performance.now();
    assert(end - start >= 10);
    resolvable.resolve();
  }, 10);
  await resolvable;
});

unitTest(function performanceMark() {
  const mark = performance.mark("test");
  assert(mark instanceof PerformanceMark);
  assertEquals(mark.detail, null);
  assertEquals(mark.name, "test");
  assertEquals(mark.entryType, "mark");
  assert(mark.startTime > 0);
  assertEquals(mark.duration, 0);
  const entries = performance.getEntries();
  assert(entries[entries.length - 1] === mark);
  const markEntries = performance.getEntriesByName("test", "mark");
  assert(markEntries[markEntries.length - 1] === mark);
});

unitTest(function performanceMeasure() {
  const mark = performance.mark("test");
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      try {
        const measure = performance.measure("test", "test");
        assert(measure instanceof PerformanceMeasure);
        assertEquals(measure.detail, null);
        assertEquals(measure.name, "test");
        assertEquals(measure.entryType, "measure");
        assert(measure.startTime > 0);
        assertEquals(mark.startTime, measure.startTime);
        assert(
          measure.duration >= 100,
          `duration below 100ms: ${measure.duration}`,
        );
        assert(
          measure.duration < 500,
          `duration exceeds 500ms: ${measure.duration}`,
        );
        const entries = performance.getEntries();
        assert(entries[entries.length - 1] === measure);
        const measureEntries = performance.getEntriesByName("test", "measure");
        assert(measureEntries[measureEntries.length - 1] === measure);
      } catch (e) {
        return reject(e);
      }
      resolve();
    }, 100);
  });
});