Files
pikasTech-unidesk/scripts/schedule-cli-contract-test.ts
T
2026-05-20 13:04:06 +00:00

61 lines
3.0 KiB
TypeScript

import { scheduleRetryRunObservation, scheduleRunObservation, scheduleRunsScope } from "./src/schedules";
type JsonRecord = Record<string, unknown>;
function assertCondition(condition: unknown, message: string, detail: JsonRecord = {}): void {
if (!condition) throw new Error(`${message}: ${JSON.stringify(detail)}`);
}
export function runScheduleCliContract(): JsonRecord {
const global = scheduleRunsScope(["runs", "--limit", "50"]);
assertCondition(global.scheduleId === null, "global schedule runs must not treat --limit value as schedule id", global);
assertCondition(global.limit === 50, "global schedule runs limit should be preserved", global);
const scoped = scheduleRunsScope(["runs", "unidesk-pgdata-baidu-daily", "--limit", "5"]);
assertCondition(scoped.scheduleId === "unidesk-pgdata-baidu-daily", "schedule-specific runs should preserve schedule id", scoped);
assertCondition(scoped.limit === 5, "schedule-specific runs limit should be preserved", scoped);
let numericScheduleRejected = false;
try {
scheduleRunsScope(["runs", "50"]);
} catch (error) {
numericScheduleRejected = String((error as Error).message).includes("schedule runs --limit N");
}
assertCondition(numericScheduleRejected, "numeric positional schedule id should point operators to global --limit syntax");
const timeoutObservation = scheduleRunObservation(
"unidesk-pgdata-baidu-daily",
{ body: { run: { id: "schedrun_new" } } },
{ ok: false, timedOut: true, timeoutMs: 1 },
);
assertCondition(timeoutObservation.newRunId === "schedrun_new", "schedule run output must expose newRunId even when wait times out", timeoutObservation);
assertCondition(String(timeoutObservation.observeCommand).includes("schedule runs unidesk-pgdata-baidu-daily --limit 20"), "schedule run output must expose observeCommand", timeoutObservation);
const retryObservation = scheduleRetryRunObservation("schedrun_failed", {
body: {
originalRunId: "schedrun_failed",
scheduleId: "unidesk-pgdata-baidu-daily",
newRunId: "schedrun_retry",
},
});
assertCondition(retryObservation.originalRunId === "schedrun_failed", "retry-run output must preserve originalRunId", retryObservation);
assertCondition(retryObservation.scheduleId === "unidesk-pgdata-baidu-daily", "retry-run output must expose scheduleId", retryObservation);
assertCondition(retryObservation.newRunId === "schedrun_retry", "retry-run output must expose newRunId", retryObservation);
assertCondition(String(retryObservation.observeCommand).includes("schedule runs unidesk-pgdata-baidu-daily --limit 20"), "retry-run output must expose observeCommand", retryObservation);
return {
ok: true,
checks: [
"global schedule runs limit parsing",
"schedule-specific runs parsing",
"numeric positional guard",
"run wait timeout observation",
"retry-run observation",
],
};
}
if (import.meta.main) {
process.stdout.write(`${JSON.stringify(runScheduleCliContract(), null, 2)}\n`);
}