Files
openclaw/scripts/verify.mjs
2026-05-27 00:21:12 +01:00

47 lines
1.2 KiB
JavaScript

import { performance } from "node:perf_hooks";
import { formatMs, printTimingSummary } from "./lib/check-timing-summary.mjs";
import { runManagedCommand } from "./lib/managed-child-process.mjs";
const stages = [
{ name: "check", args: ["check"] },
{ name: "test", args: ["test"] },
];
async function runStage(stage) {
console.error(`CRABBOX_PHASE:${stage.name}`);
console.error(`[verify] ${stage.name}`);
const startedAt = performance.now();
const status = await runManagedCommand({
args: stage.args,
bin: "pnpm",
});
return {
durationMs: performance.now() - startedAt,
name: stage.name,
status,
};
}
export async function main() {
const timings = [];
for (const stage of stages) {
const result = await runStage(stage);
timings.push(result);
if (result.status !== 0) {
printTimingSummary("verify", timings);
console.error(
`[verify] failed during ${stage.name} after ${formatMs(result.durationMs)}; later stages were not run`,
);
process.exitCode = result.status;
return;
}
}
printTimingSummary("verify", timings);
console.error("[verify] passed");
}
if (import.meta.main) {
await main();
}