2024-01-01 14:58:21 -05:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2023-06-30 03:46:48 -04:00
|
|
|
import * as perfHooks from "node:perf_hooks";
|
2024-11-13 09:17:01 -05:00
|
|
|
import {
|
|
|
|
monitorEventLoopDelay,
|
|
|
|
performance,
|
|
|
|
PerformanceObserver,
|
|
|
|
} from "node:perf_hooks";
|
2024-07-25 01:30:28 -04:00
|
|
|
import { assertEquals, assertThrows } from "@std/assert";
|
2023-06-30 03:46:48 -04: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 06:03:09 -05:00
|
|
|
assertEquals(
|
|
|
|
perfHooks.performance.getEntriesByName,
|
|
|
|
performance.getEntriesByName,
|
|
|
|
);
|
|
|
|
assertEquals(
|
|
|
|
perfHooks.performance.getEntriesByType,
|
|
|
|
performance.getEntriesByType,
|
|
|
|
);
|
2023-06-30 03:46:48 -04: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 06:03:09 -05:00
|
|
|
assertEquals(perfHooks.performance.getEntriesByName("event", "mark"), []);
|
|
|
|
assertEquals(perfHooks.performance.getEntriesByType("mark"), []);
|
2023-06-30 03:46:48 -04: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({
|
2024-05-23 07:59:20 -04:00
|
|
|
name: "[perf_hooks] PerformanceEntry & PerformanceObserver",
|
2023-06-30 03:46:48 -04:00
|
|
|
fn() {
|
|
|
|
assertEquals<unknown>(perfHooks.PerformanceEntry, PerformanceEntry);
|
2024-05-23 07:59:20 -04:00
|
|
|
assertEquals<unknown>(perfHooks.PerformanceObserver, PerformanceObserver);
|
2023-06-30 03:46:48 -04:00
|
|
|
},
|
|
|
|
});
|
2023-07-04 13:19:18 -04: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;
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
2024-07-10 13:47:45 -04:00
|
|
|
|
|
|
|
Deno.test("[perf_hooks]: eventLoopUtilization", () => {
|
|
|
|
const obj = performance.eventLoopUtilization();
|
|
|
|
assertEquals(typeof obj.idle, "number");
|
|
|
|
assertEquals(typeof obj.active, "number");
|
|
|
|
assertEquals(typeof obj.utilization, "number");
|
|
|
|
});
|
2024-11-13 09:17:01 -05:00
|
|
|
|
|
|
|
Deno.test("[perf_hooks]: monitorEventLoopDelay", () => {
|
|
|
|
const e = assertThrows(() => {
|
|
|
|
monitorEventLoopDelay({ resolution: 1 });
|
|
|
|
});
|
|
|
|
|
|
|
|
// deno-lint-ignore no-explicit-any
|
|
|
|
assertEquals((e as any).code, "ERR_NOT_IMPLEMENTED");
|
|
|
|
});
|