MiniCPM5-Pi-Web-Agent / scripts /smoke_local_model_web_agent.mjs
Mike0021's picture
Relax deployed local model smoke timeout
2d64a64 verified
import { chromium } from "@playwright/test";
const baseUrl = process.argv[2] || "http://localhost:5173/?device=wasm";
const executablePath = process.env.CHROMIUM_PATH || "/snap/bin/chromium";
const browser = await chromium.launch({
executablePath,
headless: true,
args: ["--no-sandbox", "--disable-dev-shm-usage"],
});
try {
const page = await browser.newPage();
page.setDefaultTimeout(600000);
const consoleLines = [];
page.on("console", (message) => {
consoleLines.push(`${message.type()}: ${message.text()}`);
});
page.on("pageerror", (error) => {
consoleLines.push(`pageerror: ${error.stack || error.message}`);
});
await page.goto(baseUrl, { waitUntil: "networkidle" });
await page.waitForFunction(() => document.querySelector("#status")?.textContent === "Ready");
const isolated = await page.evaluate(() => globalThis.crossOriginIsolated);
if (!isolated) throw new Error("Page is not cross-origin isolated.");
await page.fill("#max-new-tokens", "1");
await page.fill("#temperature", "0");
await page.click("#run");
await page.waitForFunction(() => document.querySelector("#status")?.textContent === "Agent running", null, {
timeout: 120000,
});
await page.waitForFunction(() => document.querySelector("#status")?.textContent === "Ready", null, {
timeout: 600000,
});
const transcript = await page.textContent("#transcript");
const files = await page.textContent("#files");
const events = await page.textContent("#event-log");
const modelStatus = await page.textContent("#model-status");
if (!transcript?.includes("pi sandbox result: 42")) {
throw new Error(`Expected command output in transcript.\n\nTranscript:\n${transcript}\n\nEvents:\n${events}`);
}
if (!files?.includes("hello.js")) {
throw new Error(`Expected hello.js in file listing.\n\nFiles:\n${files}`);
}
if (modelStatus !== "Model ready") {
throw new Error(`Expected MiniCPM model status to be ready, got: ${modelStatus}`);
}
console.log(JSON.stringify({ ok: true, isolated, modelStatus, transcript, files }, null, 2));
} catch (error) {
console.error(error instanceof Error ? error.stack || error.message : String(error));
throw error;
} finally {
await browser.close();
}