All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 2m2s
- qa/function-audit: playwright 行为审计工具(audit.mjs/verify-modals.mjs/pages.json) + 18 页审计产出(*.audit.md/json、summary、运行日志) - qa/visual-parity: 调试/测量辅助脚本(_dbg*.mjs/_measure.mjs/_off.mjs) - core/还原度核对报告.md: 18 页 pixelmatch 核对结果(含 vite 代理陈旧坑记录) - core/还原与接口待办.md: 逐页还原度/真实数据/交互接入待办总表 - .claude/skills/pixel-perfect-react: 像素级还原 React 的 SKILL 文档 - frontend/public/_devlogin.html: 临时本地登录辅助页(可删) Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
16 lines
1.1 KiB
JavaScript
16 lines
1.1 KiB
JavaScript
import { chromium } from "playwright";
|
|
const TOK = process.argv[2];
|
|
async function prepare(page, url, token) {
|
|
if (token) { await page.goto(new URL(url).origin + "/", { waitUntil: "domcontentloaded" }); await page.evaluate((v)=>localStorage.setItem("airshelf_token",v), token); }
|
|
await page.goto(url, { waitUntil: "networkidle" });
|
|
if (token) { await page.evaluate((v)=>localStorage.setItem("airshelf_token",v), token); await page.goto(url, { waitUntil: "networkidle" }); await page.waitForTimeout(900); }
|
|
}
|
|
const b = await chromium.launch();
|
|
const ctx = await b.newContext({ viewport:{width:1440,height:900}, deviceScaleFactor:1, colorScheme:"light", reducedMotion:"reduce" });
|
|
const sp = await ctx.newPage(); const tp = await ctx.newPage();
|
|
await prepare(sp, "http://127.0.0.1:5173/exact/model-photo.html", TOK);
|
|
await prepare(tp, "http://127.0.0.1:5173/model-photo", TOK);
|
|
const t = await tp.evaluate(()=>{const x=document.body.innerText||"";return {login:x.includes("AUTH/LOGIN"),first:x.replace(/\s+/g," ").slice(0,60),tok:localStorage.getItem("airshelf_token")?.length};});
|
|
console.log("TARGET after exact-compare-flow:", JSON.stringify(t));
|
|
await b.close();
|