mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-28 03:33:52 +00:00
fix(e2e): backstop Parallels update jobs
This commit is contained in:
88
test/scripts/parallels-update-job-timeout.test.ts
Normal file
88
test/scripts/parallels-update-job-timeout.test.ts
Normal file
@@ -0,0 +1,88 @@
|
||||
import { afterEach, describe, expect, it, vi } from "vitest";
|
||||
import { runTimedUpdateJob } from "../../scripts/e2e/parallels/update-job-timeout.ts";
|
||||
|
||||
describe("Parallels update job timeout", () => {
|
||||
afterEach(() => {
|
||||
vi.useRealTimers();
|
||||
});
|
||||
|
||||
it("passes after the update body completes", async () => {
|
||||
const chunks: string[] = [];
|
||||
const writeLog = vi.fn(async () => undefined);
|
||||
|
||||
await expect(
|
||||
runTimedUpdateJob({
|
||||
append: (chunk) => chunks.push(chunk),
|
||||
label: "macOS",
|
||||
run: async () => undefined,
|
||||
timeoutDescription: "1s",
|
||||
timeoutMs: 1000,
|
||||
writeLog,
|
||||
}),
|
||||
).resolves.toBe(0);
|
||||
|
||||
expect(chunks).toEqual([]);
|
||||
expect(writeLog).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
|
||||
it("records update failures and writes the job log", async () => {
|
||||
const chunks: string[] = [];
|
||||
const writeLog = vi.fn(async () => undefined);
|
||||
|
||||
await expect(
|
||||
runTimedUpdateJob({
|
||||
append: (chunk) => chunks.push(chunk),
|
||||
label: "Linux",
|
||||
run: async () => {
|
||||
throw new Error("package swap failed");
|
||||
},
|
||||
timeoutDescription: "1s",
|
||||
timeoutMs: 1000,
|
||||
writeLog,
|
||||
}),
|
||||
).resolves.toBe(1);
|
||||
|
||||
expect(chunks).toEqual(["package swap failed\n"]);
|
||||
expect(writeLog).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
|
||||
it("lets the inner bounded operation settle before the backstop fires", async () => {
|
||||
vi.useFakeTimers();
|
||||
const chunks: string[] = [];
|
||||
const writeLog = vi.fn(async () => undefined);
|
||||
|
||||
const result = runTimedUpdateJob({
|
||||
append: (chunk) => chunks.push(chunk),
|
||||
label: "macOS",
|
||||
run: () => new Promise<void>((resolve) => setTimeout(resolve, 1000)),
|
||||
timeoutDescription: "1s plus cleanup backstop",
|
||||
timeoutMs: 1200,
|
||||
writeLog,
|
||||
});
|
||||
|
||||
await vi.advanceTimersByTimeAsync(1000);
|
||||
await expect(result).resolves.toBe(0);
|
||||
expect(chunks).toEqual([]);
|
||||
expect(writeLog).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
|
||||
it("fails and writes the job log when the update body hangs", async () => {
|
||||
vi.useFakeTimers();
|
||||
const chunks: string[] = [];
|
||||
const writeLog = vi.fn(async () => undefined);
|
||||
|
||||
const result = runTimedUpdateJob({
|
||||
append: (chunk) => chunks.push(chunk),
|
||||
label: "Windows",
|
||||
run: () => new Promise(() => undefined),
|
||||
timeoutDescription: "1s",
|
||||
timeoutMs: 1000,
|
||||
writeLog,
|
||||
});
|
||||
|
||||
await vi.advanceTimersByTimeAsync(1000);
|
||||
await expect(result).resolves.toBe(1);
|
||||
expect(chunks).toEqual(["Windows update timed out after 1s\n"]);
|
||||
expect(writeLog).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user