sfc-gh-dflippo / playwright-mcp
Install for your project team
Run this command in your project directory to install the skill for your entire team:
mkdir -p .claude/skills/playwright-mcp && curl -o .claude/skills/playwright-mcp/SKILL.md https://fastmcp.me/Skills/DownloadRaw?id=32
Project Skills
This skill will be saved in .claude/skills/playwright-mcp/ and checked into git. All team members will have access to it automatically.
Important: Please verify the skill by reviewing its instructions before using it.
Browser testing, web scraping, and UI validation using Playwright MCP. Use this skill when you need to test Streamlit apps, validate web interfaces, test responsive design, check accessibility, or automate browser interactions through MCP tools.
3 views
0 installs
Skill Content
--- name: playwright-mcp description: Browser testing, web scraping, and UI validation using Playwright MCP. Use this skill when you need to test Streamlit apps, validate web interfaces, test responsive design, check accessibility, or automate browser interactions through MCP tools. --- # Playwright MCP Testing Automate browser testing, web scraping, and UI validation using Playwright MCP server for comprehensive browser automation. ## Quick Start **Core Testing Workflow:** 1. Navigate to application 2. Take snapshot (accessibility tree) 3. Interact with elements 4. Verify expected behavior 5. Take screenshots for documentation ## Key Tools ### Navigation & Waiting - `browser_navigate` - Load URL - `browser_wait_for` - Wait for time, text, or element ### Interaction - `browser_click` - Click buttons and elements - `browser_fill_form` - Batch fill multiple form fields - `browser_type` - Type into inputs - `browser_select_option` - Select dropdown options ### Validation - `browser_snapshot` - Accessibility tree (for AI analysis) - `browser_take_screenshot` - Visual capture - `browser_console_messages` - Check for JavaScript errors ## Testing Patterns ### Page Load Verification ``` Navigate to http://localhost:8501 Wait 5 seconds Take snapshot Verify expected elements present ``` ### Form Testing ``` Fill form fields (use browser_fill_form for speed) Click Submit button Wait for "Success" text to appear Take screenshot ``` ### Responsive Design ``` Resize to 375x667 (mobile) Take screenshot Resize to 1920x1080 (desktop) Take screenshot ``` ### Multi-Page Navigation ``` Navigate to homepage Click navigation link Verify URL changed Verify new page content ``` ## Best Practices ✅ **DO:** - Use `browser_snapshot` for AI analysis - Wait for content (3-5 seconds) - Batch form fields with `browser_fill_form` - Use element refs from snapshots for reliable clicks - Check console for errors ❌ **AVOID:** - Using screenshots when you need to interact - Typing each field individually - Skipping waits for dynamic content - Ignoring console errors ## Common Workflows ### Pre-Deployment Testing - Test all pages load without errors - Verify navigation works - Test forms submit successfully - Check data displays correctly - Validate responsive design (375, 768, 1920px) - Check console for JavaScript errors ### Accessibility Validation - Take snapshot of each page - Verify interactive elements have labels - Check heading hierarchy - Verify form labels associated ### Visual Regression - Take full-page screenshots - Compare with baseline - Document changes ## Quick Reference ### Common Test Flow ``` Navigate to http://localhost:8501 Wait 5 seconds Take snapshot Click element with ref from snapshot Wait for "Success" text Take screenshot ``` ### Responsive Testing ``` Resize to 375x667 # Mobile Take screenshot Resize to 768x1024 # Tablet Take screenshot Resize to 1920x1080 # Desktop Take screenshot ``` ### Form Testing ``` Fill form fields (batch) Click Submit Wait for success message Verify in snapshot ``` ### Error Checking ``` Get console messages (onlyErrors=true) Get network requests Verify no 404s or 500s ``` --- ## Troubleshooting | Issue | Solution | |-------|----------| | Browsers not installed | Run `npx @playwright/mcp browser install` | | Element not found | Take snapshot first to get current page state and exact ref | | Tests too slow | Use `browser_fill_form` instead of multiple `browser_type` | | MCP not starting | Restart IDE, verify `mcp.json` is valid JSON | | Timeout errors | Increase wait times or use `browser_wait_for` with specific conditions | | Screenshots blank | Ensure page is fully loaded before taking screenshot | | Console errors not showing | Use `browser_console_messages` with `onlyErrors=true` parameter | --- ## Resources - `TESTING_PATTERNS.md` - Common test scenarios (coming soon) - `STREAMLIT_TESTING.md` - Streamlit-specific patterns (coming soon) - `ACCESSIBILITY.md` - Accessibility testing workflows (coming soon) - `mcp-config.json` - MCP server configuration