MiniCPM5-Pi-Web-Agent-Static / scripts /smoke_web_agent.mjs
Mike0021's picture
Use Qwen2.5 Coder planner and verified token caps
53f8186 verified
import { chromium } from "@playwright/test";
import { existsSync } from "node:fs";
const baseUrl = process.argv[2] || "http://localhost:5173/?mode=mock&device=wasm";
const executablePath = process.env.CHROMIUM_PATH || (existsSync("/usr/bin/google-chrome") ? "/usr/bin/google-chrome" : "/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(90000);
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: "domcontentloaded" });
const isolated = await page.evaluate(() => globalThis.crossOriginIsolated);
if (!isolated) {
throw new Error("Page is not cross-origin isolated.");
}
await page.waitForFunction(() => document.querySelector("#status")?.textContent === "Ready");
await page.click("#send");
await page.waitForFunction(() => document.querySelector("#status")?.textContent === "Agent running", null, {
timeout: 120000,
});
await page.waitForFunction(() => window.__piWebAgent?.transcript?.includes("pi sandbox result: 42"), null, {
timeout: 120000,
});
await page.waitForFunction(() => document.querySelector("#status")?.textContent === "Ready");
const transcript = await page.evaluate(() => window.__piWebAgent?.transcript || "");
const chatText = await page.textContent("#chat");
const files = await page.textContent("#files");
const events = await page.textContent("#event-log");
if (!transcript.includes("pi sandbox result: 42") || !chatText?.includes("pi sandbox result: 42")) {
throw new Error(`Expected command output in chat transcript.\n\nTranscript:\n${transcript}\n\nChat:\n${chatText}\n\nEvents:\n${events}`);
}
if (!files?.includes("hello.js")) {
throw new Error(`Expected hello.js in file listing.\n\nFiles:\n${files}`);
}
if (!events?.includes("run_command finished")) {
throw new Error(`Expected pi tool execution events.\n\nEvents:\n${events}`);
}
console.log(JSON.stringify({ ok: true, isolated, transcript, files }, null, 2));
} catch (error) {
console.error(error instanceof Error ? error.stack || error.message : String(error));
throw error;
} finally {
await browser.close();
}