Webapp Testing

作者: Anthropic

使用 Playwright 與本地網頁應用程式互動及測試的工具包。支援驗證前端功能、除錯 UI 行為、擷取瀏覽器螢幕截圖,以及檢視瀏覽器日誌。 授權條款:完整條款請見 LICENSE.txt

npx skills add https://github.com/anthropics/skills --skill webapp-testing

Web Application Testing

To test local web applications, write native Python Playwright scripts.

Helper Scripts Available:

  • scripts/with_server.py - Manages server lifecycle (supports multiple servers)

Always run scripts with --help first to see usage. DO NOT read the source until you try running the script first and find that a customized solution is abslutely necessary. These scripts can be very large and thus pollute your context window. They exist to be called directly as black-box scripts rather than ingested into your context window.

Decision Tree: Choosing Your Approach

User task → Is it static HTML?
    ├─ Yes → Read HTML file directly to identify selectors
    │         ├─ Success → Write Playwright script using selectors
    │         └─ Fails/Incomplete → Treat as dynamic (below)
    │
    └─ No (dynamic webapp) → Is the server already running?
        ├─ No → Run: python scripts/with_server.py --help
        │        Then use the helper + write simplified Playwright script
        │
        └─ Yes → Reconnaissance-then-action:
            1. Navigate and wait for networkidle
            2. Take screenshot or inspect DOM
            3. Identify selectors from rendered state
            4. Execute actions with discovered selectors

Example: Using with_server.py

To start a server, run --help first, then use the helper:

Single server:

python scripts/with_server.py --server "npm run dev" --port 5173 -- python your_automation.py

Multiple servers (e.g., backend + frontend):

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

To create an automation script, include only Playwright logic (servers are managed automatically):

from playwright.sync_api import sync_playwright

with sync_playwright() as p:
    browser = p.chromium.launch(headless=True) # Always launch chromium in headless mode
    page = browser.new_page()
    page.goto('http://localhost:5173') # Server already running and ready
    page.wait_for_load_state('networkidle') # CRITICAL: Wait for JS to execute
    # ... your automation logic
    browser.close()

Reconnaissance-Then-Action Pattern

  1. Inspect rendered DOM:

    page.screenshot(path='/tmp/inspect.png', full_page=True)
    content = page.content()
    page.locator('button').all()
    
  2. Identify selectors from inspection results

  3. Execute actions using discovered selectors

Common Pitfall

Don't inspect the DOM before waiting for networkidle on dynamic apps ✅ Do wait for page.wait_for_load_state('networkidle') before inspection

Best Practices

  • Use bundled scripts as black boxes - To accomplish a task, consider whether one of the scripts available in scripts/ can help. These scripts handle common, complex workflows reliably without cluttering the context window. Use --help to see usage, then invoke directly.
  • Use sync_playwright() for synchronous scripts
  • Always close the browser when done
  • Use descriptive selectors: text=, role=, CSS selectors, or IDs
  • Add appropriate waits: page.wait_for_selector() or page.wait_for_timeout()

Reference Files

  • examples/ - Examples showing common patterns:
    • element_discovery.py - Discovering buttons, links, and inputs on a page
    • static_html_automation.py - Using file:// URLs for local HTML
    • console_logging.py - Capturing console logs during automation

來自 Anthropic 的更多技能

Algorithmic Art
Anthropic
使用p5.js建立演算法藝術,包含種子隨機性與互動式參數探索。當使用者要求以程式碼創作藝術、生成式藝術、演算法藝術、流場或粒子系統時使用此功能。創作原創演算法藝術,避免抄襲現有藝術家作品以規避版權問題。 授權:完整條款請見LICENSE.txt
creativeofficial
Brand Guidelines
Anthropic
將Anthropic官方品牌色彩與字體應用於任何可能需要呈現Anthropic風格與視覺感受的成品。當涉及品牌色彩、風格指南、視覺格式或公司設計標準時使用此規範。 授權:完整條款請見LICENSE.txt
creativeofficial
Canvas Design
Anthropic
使用設計理念在 .png 和 .pdf 文件中創作精美的視覺藝術。當使用者要求製作海報、藝術作品、設計或其他靜態作品時,應使用此技能。創作原創視覺設計,切勿抄襲現有藝術家的作品以避免版權侵權。 授權條款:完整條款請見 LICENSE.txt
creativeofficial
Docx
Anthropic
全面的文件建立、編輯與分析,支援追蹤修訂、註解、格式保留及文字擷取。當Claude需要處理專業文件(.docx檔案)以進行:(1) 建立新文件、(2) 修改或編輯內容、(3) 處理追蹤修訂、(4) 新增註解,或其他文件相關任務時適用。 授權:專有軟體。完整條款請見LICENSE.txt。
documentofficial
Frontend Design
Anthropic
生成獨特且具備生產級品質的前端介面,避免常見的AI美學風格。
developmentfeaturedofficial
Internal Comms
Anthropic
一套資源,幫助我撰寫各種內部溝通內容,使用公司偏好的格式。每當需要撰寫內部溝通文件(如狀態報告、領導層更新、第三方更新、公司通訊、常見問題、事件報告、專案更新等)時,Claude 應使用此技能。 授權:完整條款請見 LICENSE.txt
official
MCP Builder
Anthropic
建立高品質 MCP(模型上下文協定)伺服器的指南,讓大型語言模型能透過設計完善的工具與外部服務互動。適用於建置 MCP 伺服器以整合外部 API 或服務時,無論是使用 Python(FastMCP)或 Node/TypeScript(MCP SDK)。 授權條款:完整條款請見 LICENSE.txt
developmentofficial
Artifacts Builder
Anthropic
用於創建精緻、多組件 claude.ai HTML 工件的一套工具,採用現代前端網頁技術(React、Tailwind CSS、shadcn/ui)。適用於需要狀態管理、路由或 shadcn/ui 元件的複雜工件,不適用於簡單的單一檔案 HTML/JSX 工件。 授權條款:完整條款請見 LICENSE.txt
development