name: "Vibe Check - Browser Automation" description: "Browser automation for AI agents. Navigate pages, fill forms, click elements, take screenshots, and manage tabs — all through simple CLI commands. 2.6k+ GitHub stars." version: 1.0.0 author: vibiumdev license: MIT tags: [browser-automation, vibe-coding, ai-agent, chrome, cli, testing, web-scraping] testingTypes: [e2e, visual, accessibility] frameworks: [playwright] languages: [typescript, javascript, python, go] domains: [web, mobile] agents: [claude-code, cursor, github-copilot, windsurf, codex, aider, continue, cline, zed, bolt, opencode, gemini-cli, amp]
Vibium Browser Automation — CLI Reference
The vibium CLI automates Chrome via the command line. The browser auto-launches on first use (daemon mode keeps it running between commands).
vibium go <url> && vibium map && vibium click @e1 && vibium map
Core Workflow
Every browser automation follows this pattern:
- Navigate:
vibium go <url> - Map:
vibium map(get element refs like@e1,@e2) - Interact: Use refs to click, fill, select — e.g.
vibium click @e1 - Re-map: After navigation or DOM changes, get fresh refs with
vibium map
Binary Resolution
Before running any commands, resolve the vibium binary path once:
- Try
vibiumdirectly (works if globally installed vianpm install -g vibium) - Fall back to
./clicker/bin/vibium(dev environment, in project root) - Fall back to
./node_modules/.bin/vibium(local npm install)
Run vibium --help (or the resolved path) to confirm. Use the resolved path for all subsequent commands.
Windows note: Use forward slashes in paths (e.g. ./clicker/bin/vibium.exe) and quote paths containing spaces.
Command Chaining
Chain commands with && to run them sequentially. The chain stops on first error:
vibium go https://example.com && vibium map && vibium click @e3 && vibium diff map
When to chain: Use && for sequences that should happen back-to-back (navigate → interact → verify). Run commands separately when you need to inspect output between steps.
When NOT to chain: Don't chain commands that depend on parsing the previous output (e.g. reading map output to decide what to click). Run those separately so you can analyze the result first.
Commands
Discovery
vibium map— map interactive elements with @refs (recommended before interacting)vibium map --selector "nav"— scope map to elements within a CSS subtreevibium diff map— compare current vs last map (see what changed)
Navigation
vibium go <url>— go to a pagevibium back— go back in historyvibium forward— go forward in historyvibium reload— reload the current pagevibium url— print current URLvibium title— print page title
Reading Content
vibium text— get all page textvibium text "<selector>"— get text of a specific elementvibium html— get page HTML (use--outerfor outerHTML)vibium find "<selector>"— find element, return@e1ref (clickable withvibium click @e1)vibium find --text "Sign In"— find element by text content →@e1vibium find --label "Email"— find input by label →@e1vibium find --placeholder "Search"— find by placeholder →@e1vibium find --testid "submit-btn"— find by data-testid →@e1vibium find --xpath "//div[@class]"— find by XPath →@e1vibium find --alt "Logo"— find by alt attribute →@e1vibium find --title "Settings"— find by title attribute →@e1vibium find-all "<selector>"— find all matching elements →@e1,@e2, ... (--limit N)vibium find --role <role>— find element by ARIA role →@e1(combine with--text,--label, etc.)vibium eval "<js>"— run JavaScript and print result (--stdinto read from stdin)vibium count "<selector>"— count matching elementsvibium screenshot -o file.png— capture screenshot (--full-page,--annotate)vibium a11y-tree— accessibility tree (--everythingfor all nodes)
Interaction
vibium click "<selector>"— click an element (also accepts@reffrom map)vibium dblclick "<selector>"— double-click an elementvibium type "<selector>" "<text>"— type into an input (appends to existing value)vibium fill "<selector>" "<text>"— clear field and type new text (replaces value)vibium press <key> [selector]— press a key on element or focused elementvibium focus "<selector>"— focus an elementvibium hover "<selector>"— hover over an elementvibium scroll [direction]— scroll page (--amount N,--selector)vibium scroll-into-view "<selector>"— scroll element into view (centered)vibium keys "<combo>"— press keys (Enter, Control+a, Shift+Tab)vibium select "<selector>" "<value>"— pick a dropdown optionvibium check "<selector>"— check a checkbox/radio (idempotent)vibium uncheck "<selector>"— uncheck a checkbox (idempotent)
Mouse Primitives
vibium mouse-click [x] [y]— click at coordinates or current position (--button 0|1|2)vibium mouse-move <x> <y>— move mouse to coordinatesvibium mouse-down— press mouse button (--button 0|1|2)vibium mouse-up— release mouse button (--button 0|1|2)vibium drag "<source>" "<target>"— drag from one element to another
Element State
vibium value "<selector>"— get input/textarea/select valuevibium attr "<selector>" "<attribute>"— get HTML attribute valuevibium is-visible "<selector>"— check if element is visible (true/false)vibium is-enabled "<selector>"— check if element is enabled (true/false)vibium is-checked "<selector>"— check if checkbox/radio is checked (true/false)
Waiting
vibium wait "<selector>"— wait for element (--state visible|hidden|attached,--timeout ms)vibium wait-for-url "<pattern>"— wait until URL contains substring (--timeout ms)vibium wait-for-load— wait until page is fully loaded (--timeout ms)vibium wait-for-text "<text>"— wait until text appears on page (--timeout ms)vibium wait-for-fn "<expression>"— wait until JS expression returns truthy (--timeout ms)vibium sleep <ms>— pause execution (max 30000ms)
Capture
vibium screenshot -o file.png— capture screenshot (--full-page,--annotate)vibium pdf -o file.pdf— save page as PDF
Dialogs
vibium dialog accept [text]— accept dialog (optionally with prompt text)vibium dialog dismiss— dismiss dialog
Emulation
vibium set-viewport <width> <height>— set viewport size (--dprfor device pixel ratio)vibium viewport— get current viewport dimensionsvibium window— get OS browser window dimensions and statevibium set-window <width> <height> [x] [y]— set window size and position (--state)vibium emulate-media— override CSS media features (--color-scheme,--reduced-motion,--forced-colors,--contrast,--media)vibium set-geolocation <lat> <lng>— override geolocation (--accuracy)vibium set-content "<html>"— replace page HTML (--stdinto read from stdin)
Frames
vibium frames— list all iframes on the pagevibium frame "<nameOrUrl>"— find a frame by name or URL substring
File Upload
vibium upload "<selector>" <files...>— set files on input[type=file]
Tracing
vibium trace start— start recording (--screenshots,--snapshots,--name)vibium trace stop— stop recording and save ZIP (-o path)
Cookies
vibium cookies— list all cookiesvibium cookies set <name> <value>— set a cookievibium cookies clear— clear all cookies
Storage State
vibium storage-state— export cookies + localStorage + sessionStorage (-o state.json)vibium restore-storage <path>— restore state from JSON file
Downloads
vibium download set-dir <path>— set download directory
Tabs
vibium tabs— list open tabsvibium tab-new [url]— open new tabvibium tab-switch <index|url>— switch tabvibium tab-close [index]— close tab
Debug
vibium highlight "<selector>"— highlight element visually (3 seconds)
Session
vibium quit— close the browser (daemon keeps running)vibium close— alias for quitvibium daemon start— start background browservibium daemon status— check if runningvibium daemon stop— stop daemon
Common Patterns
Ref-based workflow (recommended for AI)
vibium go https://example.com
vibium map
vibium click @e1
vibium map # re-map after interaction
Verify action worked
vibium map
vibium click @e3
vibium diff map # see what changed
Read a page
vibium go https://example.com && vibium text
Fill a form (end-to-end)
vibium go https://example.com/login
vibium map
# Look at map output to identify form fields
vibium fill @e1 "user@example.com"
vibium fill @e2 "secret"
vibium click @e3
vibium wait-for-url "/dashboard"
vibium screenshot -o after-login.png
Scoped map (large pages)
vibium map --selector "nav" # Only map elements in <nav>
vibium map --selector "#sidebar" # Only map elements in #sidebar
vibium map --selector "form" # Only map form controls
Semantic find (no CSS selectors needed)
vibium find --text "Sign In" # → @e1 [button] "Sign In"
vibium find --label "Email" # → @e1 [input] placeholder="Email"
vibium click @e1 # Click the found element
vibium find --placeholder "Search..." # → @e1 [input] placeholder="Search..."
vibium find --testid "submit-btn" # → @e1 [button] "Submit"
vibium find --alt "Company logo" # → @e1 [img] alt="Company logo"
vibium find --title "Close" # → @e1 [button] title="Close"
vibium find --xpath "//a[@href='/about']" # → @e1 [a] "About"
Authentication with state persistence
# Log in once and save state
vibium go https://app.example.com/login
vibium fill "input[name=email]" "user@example.com"
vibium fill "input[name=password]" "secret"
vibium click "button[type=submit]"
vibium wait-for-url "/dashboard"
vibium storage-state -o auth.json
# Restore in a later session (skips login)
vibium restore-storage auth.json
vibium go https://app.example.com/dashboard
Extract structured data
vibium go https://example.com
vibium eval "JSON.stringify([...document.querySelectorAll('a')].map(a => ({text: a.textContent.trim(), href: a.href})))"
Check page structure without rendering
vibium go https://example.com && vibium a11y-tree
Multi-tab workflow
vibium tab-new https://docs.example.com
vibium text "h1"
vibium tab-switch 0
Annotated screenshot
vibium screenshot -o annotated.png --annotate
Inspect an element
vibium attr "a" "href"
vibium value "input[name=email]"
vibium is-visible ".modal"
Save as PDF
vibium go https://example.com && vibium pdf -o page.pdf
Eval / JavaScript
vibium eval is the escape hatch for any DOM query or mutation the CLI doesn't cover directly.
Simple expressions — use single quotes:
vibium eval 'document.title'
vibium eval 'document.querySelectorAll("li").length'
Complex scripts — use --stdin with a heredoc:
vibium eval --stdin <<'EOF'
const rows = [...document.querySelectorAll('table tbody tr')];
JSON.stringify(rows.map(r => {
const cells = r.querySelectorAll('td');
return { name: cells[0].textContent.trim(), price: cells[1].textContent.trim() };
}));
EOF
JSON output — use --json to get machine-readable output:
vibium eval --json 'JSON.stringify({url: location.href, title: document.title})'
Timeouts and Waiting
All interaction commands (click, fill, type, etc.) auto-wait for the target element to be actionable. You usually don't need explicit waits.
Use explicit waits when:
- Waiting for navigation:
vibium wait-for-url "/dashboard"— after clicking a link that navigates - Waiting for content:
vibium wait-for-text "Success"— after form submission, wait for confirmation - Waiting for element:
vibium wait ".modal"— wait for a modal to appear - Waiting for page load:
vibium wait-for-load— after navigation to a slow page - Waiting for JS condition:
vibium wait-for-fn "window.appReady === true"— wait for app initialization - Fixed delay (last resort):
vibium sleep 2000— only when no better signal exists (max 30s)
All wait commands accept --timeout <ms> (default varies by command).
Ref Lifecycle
Refs (@e1, @e2) are invalidated when the page changes. Always re-map after:
- Clicking links or buttons that navigate
- Form submissions
- Dynamic content loading (dropdowns, modals)
Global Flags
| Flag | Description |
|---|---|
--headless | Hide browser window |
--json | Output as JSON |
-v, --verbose | Debug logging |
Tips
- All click/type/hover/fill actions auto-wait for the element to be actionable
- All selector arguments also accept
@reffromvibium map - Use
vibium mapbefore interacting to discover interactive elements - Use
vibium map --selectorto reduce noise on large pages - Use
vibium fillto replace a field's value,vibium typeto append to it - Use
vibium find --text/--label/--testidfor semantic element lookup (more reliable than CSS selectors) - Use
vibium find --rolefor ARIA-role-based lookup - Use
vibium a11y-treeto understand page structure without visual rendering - Use
vibium text "<selector>"to read specific sections - Use
vibium diff mapafter interactions to see what changed vibium evalis the escape hatch for complex DOM queriesvibium check/vibium uncheckare idempotent — safe to call without checking state first- Screenshots save to the current directory by default (
-oto change) - Use
vibium storage-state/vibium restore-storageto persist auth across sessions