2025-01-01 04:12:39 +09:00
|
|
|
// Copyright 2018-2025 the Deno authors. MIT license.
|
2023-06-30 15:46:48 +08:00
|
|
|
import * as perfHooks from "node:perf_hooks";
|
2024-11-13 19:47:01 +05:30
|
|
|
import {
|
|
|
|
monitorEventLoopDelay,
|
|
|
|
performance,
|
|
|
|
PerformanceObserver,
|
|
|
|
} from "node:perf_hooks";
|
2024-11-19 16:49:25 +05:30
|
|
|
import { assert, assertEquals, assertThrows } from "@std/assert";
|
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({
|
2024-05-23 04:59:20 -07:00
|
|
|
name: "[perf_hooks] PerformanceEntry & PerformanceObserver",
|
2023-06-30 15:46:48 +08:00
|
|
|
fn() {
|
|
|
|
assertEquals<unknown>(perfHooks.PerformanceEntry, PerformanceEntry);
|
2024-05-23 04:59:20 -07:00
|
|
|
assertEquals<unknown>(perfHooks.PerformanceObserver, PerformanceObserver);
|
2023-06-30 15:46:48 +08:00
|
|
|
},
|
|
|
|
});
|
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;
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
2024-07-10 19:47:45 +02: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 19:47:01 +05:30
|
|
|
|
2024-11-19 16:49:25 +05:30
|
|
|
Deno.test("[perf_hooks]: monitorEventLoopDelay", async () => {
|
|
|
|
const e = monitorEventLoopDelay();
|
|
|
|
assertEquals(e.count, 0);
|
|
|
|
e.enable();
|
2024-11-13 19:47:01 +05:30
|
|
|
|
2024-11-19 16:49:25 +05:30
|
|
|
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
|
|
|
|
|
|
assert(e.min > 0);
|
|
|
|
assert(e.minBigInt > 0n);
|
|
|
|
assert(e.count > 0);
|
|
|
|
|
|
|
|
e.disable();
|
2024-11-13 19:47:01 +05:30
|
|
|
});
|