test: tighten transport ready coverage

This commit is contained in:
Peter Steinberger 2026-03-13 23:51:36 +00:00
parent 4c77c3a7bb
commit a5a2e487c7
1 changed files with 64 additions and 2 deletions

View File

@ -4,11 +4,25 @@ import { waitForTransportReady } from "./transport-ready.js";
// Perf: `sleepWithAbort` uses `node:timers/promises` which isn't controlled by fake timers. // Perf: `sleepWithAbort` uses `node:timers/promises` which isn't controlled by fake timers.
// Route sleeps through global `setTimeout` so tests can advance time deterministically. // Route sleeps through global `setTimeout` so tests can advance time deterministically.
vi.mock("./backoff.js", () => ({ vi.mock("./backoff.js", () => ({
sleepWithAbort: async (ms: number) => { sleepWithAbort: async (ms: number, signal?: AbortSignal) => {
if (signal?.aborted) {
throw new Error("aborted");
}
if (ms <= 0) { if (ms <= 0) {
return; return;
} }
await new Promise<void>((resolve) => setTimeout(resolve, ms)); await new Promise<void>((resolve, reject) => {
const timer = setTimeout(() => {
signal?.removeEventListener("abort", onAbort);
resolve();
}, ms);
const onAbort = () => {
clearTimeout(timer);
signal?.removeEventListener("abort", onAbort);
reject(new Error("aborted"));
};
signal?.addEventListener("abort", onAbort, { once: true });
});
}, },
})); }));
@ -81,4 +95,52 @@ describe("waitForTransportReady", () => {
}); });
expect(runtime.error).not.toHaveBeenCalled(); expect(runtime.error).not.toHaveBeenCalled();
}); });
it("stops polling when aborted during the sleep interval", async () => {
const runtime = createRuntime();
const controller = new AbortController();
let attempts = 0;
const waitPromise = waitForTransportReady({
label: "test transport",
timeoutMs: 500,
pollIntervalMs: 50,
runtime,
abortSignal: controller.signal,
check: async () => {
attempts += 1;
setTimeout(() => controller.abort(), 10);
return { ok: false, error: "still down" };
},
});
await vi.advanceTimersByTimeAsync(100);
await waitPromise;
expect(attempts).toBe(1);
expect(runtime.error).not.toHaveBeenCalled();
});
it("logs repeated unknown-error retries and the final timeout message", async () => {
const runtime = createRuntime();
const waitPromise = waitForTransportReady({
label: "test transport",
timeoutMs: 120,
logAfterMs: 0,
logIntervalMs: 50,
pollIntervalMs: 50,
runtime,
check: async () => ({ ok: false, error: null }),
});
const asserted = expect(waitPromise).rejects.toThrow(
"test transport not ready (unknown error)",
);
await vi.advanceTimersByTimeAsync(200);
await asserted;
expect(runtime.error).toHaveBeenCalledTimes(2);
expect(runtime.error.mock.calls.at(0)?.[0]).toContain("unknown error");
expect(runtime.error.mock.calls.at(-1)?.[0]).toContain("not ready after 120ms");
});
}); });