You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Fast headless browser for QA testing and site dogfooding. Navigate any URL, interact with
elements, verify page state, diff before/after actions, take annotated screenshots, check
responsive layouts, test forms and uploads, handle dialogs, and assert element states.
~100ms per command. Use when you need to test a feature, verify a deployment, dogfood a
user flow, or file a bug with evidence.
allowed-tools
Bash
Read
gstack browse: QA Testing & Dogfooding
Persistent headless Chromium. First call auto-starts (~3s), then ~100-200ms per command.
Auto-shuts down after 30 min idle. State persists between calls (cookies, tabs, sessions).
Tell the user: "gstack browse needs a one-time build (~10 seconds). OK to proceed?" Then STOP and wait.
Run: cd <SKILL_DIR> && ./setup
If bun is not installed: curl -fsSL https://bun.sh/install | bash
IMPORTANT
Use the compiled binary via Bash: $B <command>
NEVER use mcp__claude-in-chrome__* tools. They are slow and unreliable.
Browser persists between calls — cookies, login sessions, and tabs carry over.
Dialogs (alert/confirm/prompt) are auto-accepted by default — no browser lockup.
QA Workflows
Test a user flow (login, signup, checkout, etc.)
B=~/.claude/skills/gstack/browse/dist/browse
# 1. Go to the page$B goto https://app.example.com/login
# 2. See what's interactive$B snapshot -i
# 3. Fill the form using refs$B fill @e3 "test@example.com"$B fill @e4 "password123"$B click @e5
# 4. Verify it worked$B snapshot -D # diff shows what changed after clicking$B is visible ".dashboard"# assert the dashboard appeared$B screenshot /tmp/after-login.png
Verify a deployment / check prod
$B goto https://yourapp.com
$B text # read the page — does it load?$B console # any JS errors?$B network # any failed requests?$B js "document.title"# correct title?$B is visible ".hero-section"# key elements present?$B screenshot /tmp/prod-check.png
Dogfood a feature end-to-end
# Navigate to the feature$B goto https://app.example.com/new-feature
# Take annotated screenshot — shows every interactive element with labels$B snapshot -i -a -o /tmp/feature-annotated.png
# Find ALL clickable things (including divs with cursor:pointer)$B snapshot -C
# Walk through the flow$B snapshot -i # baseline$B click @e3 # interact$B snapshot -D # what changed? (unified diff)# Check element states$B is visible ".success-toast"$B is enabled "#next-step-btn"$B is checked "#agree-checkbox"# Check console for errors after interactions$B console
$B goto https://app.example.com/form
$B snapshot -i
# Submit empty — check validation errors appear$B click @e10 # submit button$B snapshot -D # diff shows error messages appeared$B is visible ".error-message"# Fill and resubmit$B fill @e3 "valid input"$B click @e10
$B snapshot -D # diff shows errors gone, success state
Test dialogs (delete confirmations, prompts)
# Set up dialog handling BEFORE triggering$B dialog-accept # will auto-accept next alert/confirm$B click "#delete-button"# triggers confirmation dialog$B dialog # see what dialog appeared$B snapshot -D # verify the item was deleted# For prompts that need input$B dialog-accept "my answer"# accept with text$B click "#rename-button"# triggers prompt
Test authenticated pages (import real browser cookies)
# Import cookies from your real browser (opens interactive picker)$B cookie-import-browser
# Or import a specific domain directly$B cookie-import-browser comet --domain .github.com
# Now test authenticated pages$B goto https://github.com/settings/profile
$B snapshot -i
$B screenshot /tmp/github-profile.png
# Element exists and is visible$B is visible ".modal"# Button is enabled/disabled$B is enabled "#submit-btn"$B is disabled "#submit-btn"# Checkbox state$B is checked "#agree"# Input is editable$B is editable "#name-field"# Element has focus$B is focused "#search-input"# Page contains text$B js "document.body.textContent.includes('Success')"# Element count$B js "document.querySelectorAll('.list-item').length"# Specific attribute value$B attrs "#logo"# returns all attributes as JSON# CSS property$B css ".button""background-color"
Snapshot System
The snapshot is your primary tool for understanding and interacting with pages.
$B snapshot -i # Interactive elements only (buttons, links, inputs) with @e refs$B snapshot -c # Compact (no empty structural elements)$B snapshot -d 3 # Limit depth to 3 levels$B snapshot -s "main"# Scope to CSS selector$B snapshot -D # Diff against previous snapshot (what changed?)$B snapshot -a # Annotated screenshot with ref labels$B snapshot -o /tmp/x.png # Output path for annotated screenshot$B snapshot -C # Cursor-interactive elements (@c refs — divs with pointer, onclick)
Combine flags: $B snapshot -i -a -C -o /tmp/annotated.png