Use Agent Browser CLI for headless browser automation and E2E testing. Invoke when user needs to automate browser tasks, run E2E tests, capture screenshots, interact with web pages, or perform web scraping tasks.
Agent Browser is a fast headless browser automation CLI designed for AI agents. Use it for E2E testing, web automation, and browser-based tasks.
# Navigate and capture state
agent-browser open https://example.com
agent-browser snapshot -i # Get interactive elements with refs (@e1, @e2, etc.)
agent-browser click @e2 # Click by reference
agent-browser screenshot page.png
agent-browser close
agent-browser open <url> # Navigate to URL
agent-browser back # Go back
agent-browser forward # Go forward
agent-browser reload # Reload page
agent-browser close # Close browser
agent-browser click <sel> # Click element (CSS selector or @ref)
agent-browser dblclick <sel> # Double-click
agent-browser type <sel> <text> # Type into element (appends)
agent-browser fill <sel> <text> # Clear and fill (replaces)
agent-browser press <key> # Press key (Enter, Tab, Control+a)
agent-browser hover <sel> # Hover over element
agent-browser focus <sel> # Focus element
agent-browser check <sel> # Check checkbox
agent-browser uncheck <sel> # Uncheck checkbox
agent-browser select <sel> <val> # Select dropdown option
agent-browser drag <src> <dst> # Drag and drop
agent-browser upload <sel> <files...> # Upload files
agent-browser scroll <dir> [px] # Scroll (up/down/left/right)
agent-browser scrollintoview <sel> # Scroll element into view
agent-browser wait <sel> # Wait for element to appear
agent-browser wait 2000 # Wait milliseconds
agent-browser screenshot [path] # Take screenshot
agent-browser screenshot --full # Full page screenshot
agent-browser pdf <path> # Save as PDF
agent-browser snapshot # Get accessibility tree with refs
agent-browser snapshot -i # Interactive elements only
agent-browser snapshot -c # Compact (remove empty elements)
agent-browser snapshot -d 3 # Limit depth
agent-browser get text <sel> # Get element text
agent-browser get html <sel> # Get element HTML
agent-browser get value <sel> # Get input value
agent-browser get attr <name> <sel> # Get attribute
agent-browser get title # Get page title
agent-browser get url # Get current URL
agent-browser get count <sel> # Count matching elements
agent-browser get box <sel> # Get bounding box
agent-browser is visible <sel> # Check if visible
agent-browser is enabled <sel> # Check if enabled
agent-browser is checked <sel> # Check if checked
agent-browser find role button click # Find by role and click
agent-browser find text "Submit" click # Find by text and click
agent-browser find label "Email" fill "[email protected]"
agent-browser find placeholder "Search..." fill "query"
agent-browser find testid "submit-btn" click
agent-browser eval "document.title" # Get title
agent-browser eval "window.scrollTo(0, 0)" # Scroll to top
agent-browser eval "localStorage.getItem('token')" # Get storage
agent-browser --session mytest open example.com # Use isolated session
agent-browser session # Show current session
agent-browser session list # List active sessions
agent-browser tab new # Open new tab
agent-browser tab list # List tabs
agent-browser tab 2 # Switch to tab 2
agent-browser tab close # Close current tab
agent-browser network requests # View network requests
agent-browser network requests --clear # Clear requests
agent-browser network route "*/api/*" --abort # Block API calls
agent-browser set offline on # Enable offline mode
agent-browser set headers '{"Auth": "token"}' # Set headers
agent-browser set viewport 1920 1080 # Set viewport size
agent-browser set device "iPhone 12" # Emulate device
agent-browser set geo 37.7749 -122.4194 # Set geolocation
agent-browser set media dark # Enable dark mode
agent-browser console # View console logs
agent-browser errors # View page errors
agent-browser highlight <sel> # Highlight element
agent-browser trace start # Start recording trace
agent-browser trace stop trace.zip # Stop and save trace
Always use --session flag for isolated testing:
# Create isolated session for E2E test
export AGENT_BROWSER_SESSION="e2e-test-$(date +%s)"
agent-browser open https://app.example.com
agent-browser snapshot -i
agent-browser fill @e5 "[email protected]"
agent-browser fill @e6 "password123"
agent-browser click @e7
agent-browser wait "[data-testid='dashboard']"
agent-browser screenshot results/login-success.png
agent-browser close
#!/bin/bash
# Example E2E test script
SESSION="test-$(date +%s)"
RESULTS_DIR="./test-results"
mkdir -p "$RESULTS_DIR"
# Setup
agent-browser --session "$SESSION" open "$BASE_URL"
# Test login flow
agent-browser --session "$SESSION" snapshot -i
agent-browser --session "$SESSION" fill "[name='email']" "$TEST_EMAIL"
agent-browser --session "$SESSION" fill "[name='password']" "$TEST_PASSWORD"
agent-browser --session "$SESSION" click "[type='submit']"
agent-browser --session "$SESSION" wait "[data-testid='dashboard']" || {
agent-browser --session "$SESSION" screenshot "$RESULTS_DIR/login-failed.png"
exit 1
}
agent-browser --session "$SESSION" screenshot "$RESULTS_DIR/login-success.png"
# Verify dashboard elements
TITLE=$(agent-browser --session "$SESSION" get text "h1")
if [[ "$TITLE" != *"Dashboard"* ]]; then
echo "FAIL: Dashboard title not found"
exit 1
fi
# Cleanup
agent-browser --session "$SESSION" close
echo "PASS: Login test completed"
| Option | Description |
|---|---|
--session <name> | Isolated browser session |
--headed | Show browser window (not headless) |
--json | JSON output format |
--full, -f | Full page screenshot |
--cdp <port> | Connect via Chrome DevTools Protocol |
--debug | Enable debug output |
| Variable | Description |
|---|---|
AGENT_BROWSER_SESSION | Default session name |
AGENT_BROWSER_EXECUTABLE_PATH | Custom browser path |
AGENT_BROWSER_STREAM_PORT | WebSocket streaming port |
close when done--headed during development to see what's happeningagent-browser open https://example.com/form
agent-browser snapshot -i
agent-browser fill "[name='email']" "[email protected]"
agent-browser fill "[name='message']" "Hello world"
agent-browser click "[type='submit']"
agent-browser wait ".success-message"
agent-browser screenshot form-submitted.png
agent-browser open https://app.example.com/login
agent-browser fill "#email" "[email protected]"
agent-browser fill "#password" "testpass123"
agent-browser click "button[type='submit']"
agent-browser wait "[data-auth='true']"
agent-browser get text ".user-name"
agent-browser open https://example.com/products
agent-browser get text ".product-title" --json
agent-browser get attr "href" ".product-link" --json
agent-browser screenshot products.png --full