2023-06-30 15:46:48 +08:00
|
|
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
|
|
import * as perfHooks from "node:perf_hooks";
|
|
|
|
import { performance } from "node:perf_hooks";
|
2023-07-05 01:19:18 +08:00
|
|
|
import {
|
|
|
|
assertEquals,
|
|
|
|
assertThrows,
|
2023-12-02 13:20:06 +11:00
|
|
|
} from "../../../test_util/std/assert/mod.ts";
|
2023-06-30 15:46:48 +08:00
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
name: "[perf_hooks] performance",
|
|
|
|
fn() {
|
|
|
|
assertEquals(perfHooks.performance.measure, performance.measure);
|
|
|
|
assertEquals(perfHooks.performance.clearMarks, performance.clearMarks);
|
|
|
|
assertEquals(perfHooks.performance.mark, performance.mark);
|
|
|
|
assertEquals(perfHooks.performance.now, performance.now);
|
2023-11-14 12:03:09 +01:00
|
|
|
assertEquals(
|
|
|
|
perfHooks.performance.getEntriesByName,
|
|
|
|
performance.getEntriesByName,
|
|
|
|
);
|
|
|
|
assertEquals(
|
|
|
|
perfHooks.performance.getEntriesByType,
|
|
|
|
performance.getEntriesByType,
|
|
|
|
);
|
2023-06-30 15:46:48 +08:00
|
|
|
// @ts-ignore toJSON is not in Performance interface
|
|
|
|
assertEquals(perfHooks.performance.toJSON, performance.toJSON);
|
|
|
|
perfHooks.performance.measure("test");
|
|
|
|
perfHooks.performance.mark("test");
|
|
|
|
perfHooks.performance.clearMarks("test");
|
|
|
|
perfHooks.performance.now();
|
2023-11-14 12:03:09 +01:00
|
|
|
assertEquals(perfHooks.performance.getEntriesByName("event", "mark"), []);
|
|
|
|
assertEquals(perfHooks.performance.getEntriesByType("mark"), []);
|
2023-06-30 15:46:48 +08:00
|
|
|
// @ts-ignore toJSON is not in Performance interface
|
|
|
|
perfHooks.performance.toJSON();
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
name: "[perf_hooks] performance destructured",
|
|
|
|
fn() {
|
|
|
|
performance.measure("test");
|
|
|
|
performance.mark("test");
|
|
|
|
performance.clearMarks("test");
|
|
|
|
performance.now();
|
|
|
|
// @ts-ignore toJSON is not in Performance interface
|
|
|
|
performance.toJSON();
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
name: "[perf_hooks] PerformanceEntry",
|
|
|
|
fn() {
|
|
|
|
assertEquals<unknown>(perfHooks.PerformanceEntry, PerformanceEntry);
|
|
|
|
},
|
|
|
|
});
|
2023-07-05 01:19:18 +08:00
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
name: "[perf_hooks] performance.timeOrigin",
|
|
|
|
fn() {
|
|
|
|
assertEquals(typeof performance.timeOrigin, "number");
|
|
|
|
assertThrows(() => {
|
|
|
|
// @ts-expect-error: Cannot assign to 'timeOrigin' because it is a read-only property
|
|
|
|
performance.timeOrigin = 1;
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|