From example-skills
Tests local web apps with Playwright Python scripts. Manages dev servers, verifies UI functionality, debugs interactions, captures screenshots and browser logs.
npx claudepluginhub joshuarweaver/cascade-code-general-misc-3 --plugin marcelleon-skills-zhThis skill uses the workspace's default tool permissions.
要测试本地 Web 应用程序,请编写本地 Python Playwright 脚本。
Applies Acme Corporation brand guidelines including colors, fonts, layouts, and messaging to generated PowerPoint, Excel, and PDF documents.
Builds DCF models with sensitivity analysis, Monte Carlo simulations, and scenario planning for investment valuation and risk assessment.
Calculates profitability (ROE, margins), liquidity (current ratio), leverage, efficiency, and valuation (P/E, EV/EBITDA) ratios from financial statements in CSV, JSON, text, or Excel for investment analysis.
要测试本地 Web 应用程序,请编写本地 Python Playwright 脚本。
可用的辅助脚本:
scripts/with_server.py - 管理服务器生命周期(支持多个服务器)始终首先使用 --help 运行脚本以查看用法。在尝试运行脚本并发现绝对必要的定制解决方案之前,不要阅读源代码。这些脚本可能非常大,因此会污染您的上下文窗口。它们的存在是为了直接作为黑盒脚本调用,而不是被摄取到您的上下文窗口中。
用户任务 → 它是静态 HTML 吗?
├─ 是 → 直接读取 HTML 文件以识别选择器
│ ├─ 成功 → 使用选择器编写 Playwright 脚本
│ └─ 失败/不完整 → 视为动态(见下文)
│
└─ 否(动态 webapp)→ 服务器是否已经运行?
├─ 否 → 运行:python scripts/with_server.py --help
│ 然后使用辅助程序 + 编写简化的 Playwright 脚本
│
└─ 是 → 侦察后行动:
1. 导航并等待 networkidle
2. 截图或检查 DOM
3. 从渲染状态识别选择器
4. 使用发现的选择器执行操作
要启动服务器,首先运行 --help,然后使用辅助程序:
单个服务器:
python scripts/with_server.py --server "npm run dev" --port 5173 -- python your_automation.py
多个服务器(例如,后端 + 前端):
python scripts/with_server.py \
--server "cd backend && python server.py" --port 3000 \
--server "cd frontend && npm run dev" --port 5173 \
-- python your_automation.py
要创建自动化脚本,仅包含 Playwright 逻辑(服务器自动管理):
from playwright.sync_api import sync_playwright
with sync_playwright() as p:
browser = p.chromium.launch(headless=True) # 始终在无头模式下启动 chromium
page = browser.new_page()
page.goto('http://localhost:5173') # 服务器已运行并准备就绪
page.wait_for_load_state('networkidle') # 关键:等待 JS 执行
# ... 您的自动化逻辑
browser.close()
检查渲染的 DOM:
page.screenshot(path='/tmp/inspect.png', full_page=True)
content = page.content()
page.locator('button').all()
从检查结果中识别选择器
使用发现的选择器执行操作
❌ 不要在动态应用程序上等待 networkidle 之前检查 DOM
✅ 要在检查之前等待 page.wait_for_load_state('networkidle')
scripts/ 中可用的脚本之一是否可以提供帮助。这些脚本可靠地处理常见的、复杂的工作流程,而不会使上下文窗口混乱。使用 --help 查看用法,然后直接调用。sync_playwright()text=、role=、CSS 选择器或 IDpage.wait_for_selector() 或 page.wait_for_timeout()element_discovery.py - 发现页面上的按钮、链接和输入static_html_automation.py - 对本地 HTML 使用 file:// URLconsole_logging.py - 在自动化期间捕获控制台日志