2020-01-02 15:13:47 -05:00
|
|
|
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
2020-07-11 12:38:15 +10:00
|
|
|
import {
|
|
|
|
unitTest,
|
|
|
|
assert,
|
|
|
|
assertEquals,
|
|
|
|
createResolvable,
|
|
|
|
} from "./test_util.ts";
|
2019-02-02 09:27:42 +03:00
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest({ perms: { hrtime: false } }, async function performanceNow(): Promise<
|
|
|
|
void
|
|
|
|
> {
|
2020-03-03 18:22:53 +01:00
|
|
|
const resolvable = createResolvable();
|
2019-02-02 09:27:42 +03:00
|
|
|
const start = performance.now();
|
2019-04-21 16:40:10 -04:00
|
|
|
setTimeout((): void => {
|
2019-02-02 09:27:42 +03:00
|
|
|
const end = performance.now();
|
|
|
|
assert(end - start >= 10);
|
2020-03-03 18:22:53 +01:00
|
|
|
resolvable.resolve();
|
2019-02-02 09:27:42 +03:00
|
|
|
}, 10);
|
2020-03-03 18:22:53 +01:00
|
|
|
await resolvable;
|
2019-02-02 09:27:42 +03:00
|
|
|
});
|
2020-07-11 12:38:15 +10:00
|
|
|
|
|
|
|
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);
|
2020-07-13 14:50:57 +10:00
|
|
|
assert(
|
|
|
|
measure.duration >= 100,
|
|
|
|
`duration below 100ms: ${measure.duration}`
|
|
|
|
);
|
|
|
|
assert(
|
|
|
|
measure.duration < 500,
|
|
|
|
`duration exceeds 500ms: ${measure.duration}`
|
|
|
|
);
|
2020-07-11 12:38:15 +10:00
|
|
|
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);
|
|
|
|
});
|
|
|
|
});
|