Playwright CLI
Automate browsers through shell commands via the Bash tool.
Core Workflow
Every interaction follows this pattern:
- Open a page:
playwright-cli open <url> - Snapshot to discover elements:
playwright-cli snapshot - Interact using refs from the snapshot:
playwright-cli click <ref> - Verify the result:
playwright-cli screenshotorplaywright-cli snapshot
Always run snapshot before interacting — element refs come exclusively from
snapshot output and become stale after navigation.
Command Reference
Navigation
| Command | Description |
|---------|-------------|
| open <url> | Open URL in new page |
| goto <url> | Navigate current page |
| go-back / go-forward | Browser back/forward |
| reload | Reload current page |
| close | Close the browser |
Interaction
| Command | Description |
|---------|-------------|
| click <ref> | Click an element |
| dblclick <ref> | Double-click an element |
| fill <ref> <text> | Clear field, then type text |
| type <text> | Type into focused element (appends) |
| check <ref> / uncheck <ref> | Toggle checkbox |
| select <ref> <values> | Select dropdown option(s) |
| hover <ref> | Hover over element |
| drag <start> <end> | Drag between elements |
| upload <ref> <paths> | Upload file(s) to file input |
| eval "<js>" | Evaluate JavaScript on page |
| eval "<js>" <ref> | Evaluate JavaScript on element |
| dialog-accept [text] | Accept dialog (optional prompt text) |
| dialog-dismiss | Dismiss dialog |
| resize <w> <h> | Resize browser window |
Output
| Command | Description |
|---------|-------------|
| screenshot [ref] [--filename=f] | Capture PNG screenshot (page or element) |
| snapshot [--filename=f] | Accessibility tree — structured, token-efficient |
| pdf [--filename=f] | Generate PDF of the page |
Important:
--filenameresolves relative to the working directory, NOToutputDir. When using--filename, always prepend the project'soutputDirvalue (check.playwright/cli.config.json; defaults to.playwright-cli). Example:playwright-cli screenshot --filename=<outputDir>/my-screenshot.png
Tabs
| Command | Description |
|---------|-------------|
| tab list | List open tabs |
| tab create [url] | Open new tab |
| tab select <index> | Switch to tab |
| tab close [index] | Close tab |
Keyboard
playwright-cli press Enter # Enter, Tab, Escape, ArrowDown, etc.
playwright-cli keydown Shift # Hold key down
playwright-cli keyup Shift # Release key
Mouse
playwright-cli mousemove 150 300 # Move to coordinates
playwright-cli mousedown [button] # Press button (left/right)
playwright-cli mouseup [button] # Release button
playwright-cli mousewheel 0 100 # Scroll (deltaX deltaY)
Sessions
- Default session — all commands share one session automatically
- Named sessions —
playwright-cli -s=<name> open <url>for parallel browsers - List sessions —
playwright-cli list - Close one —
playwright-cli -s=<name> close - Close all —
playwright-cli close-all - Force kill —
playwright-cli kill-all - Persistent profile —
playwright-cli open <url> --persistent - Custom profile —
playwright-cli open <url> --profile=/path/to/dir - Delete data —
playwright-cli delete-dataorplaywright-cli -s=<name> delete-data - Environment variable —
PLAYWRIGHT_CLI_SESSION=my-project
Configuration
playwright-cli open <url> --browser=chromium # chromium (default), firefox, webkit, chrome, msedge
playwright-cli open <url> --headed # Visible browser window
playwright-cli open <url> --config=config.json # Custom config file
playwright-cli open <url> --extension # Connect via browser extension
Create .playwright/cli.config.json in the project for persistent settings:
{ "browser": { "browserName": "chromium", "launchOptions": { "headless": true } }, "outputDir": ".playwright-cli", "timeouts": { "action": 5000, "navigation": 60000 } }
Other options: network.allowedOrigins, network.blockedOrigins, saveVideo.
Environment variables use PLAYWRIGHT_MCP_ prefix (e.g., PLAYWRIGHT_MCP_BROWSER=firefox).
Common Pitfalls
- Interacting without snapshot — refs are unknown until
snapshotruns - Stale refs after navigation — re-run
snapshotaftergoto, link clicks, or form submissions - fill vs type —
fillclears the field first;typeappends to current content - Stuck sessions — run
playwright-cli kill-allto force-close all browsers
Resources
- EXAMPLES.md — Multi-step workflow examples
- TROUBLESHOOTING.md — Error diagnosis and fixes
- references/request-mocking.md — Intercept, mock, and block network requests
- references/running-code.md — Execute arbitrary Playwright code via
run-code - references/session-management.md — Named sessions, isolation, concurrent browsers
- references/storage-state.md — Cookies, localStorage, sessionStorage management
- references/test-generation.md — Generate Playwright test code from CLI actions
- references/tracing.md — Capture execution traces for debugging
- references/video-recording.md — Record browser sessions as WebM video