.claude/skills/chrome-browser/SKILL.md
Browser automation with two integrations - Chrome DevTools MCP (always available, performance tracing) and Claude-in-Chrome extension (authenticated sessions, GIF recording). Use DevTools for testing/debugging, Claude-in-Chrome for authenticated workflows.
npx skillsauth add oimiragieo/agent-studio chrome-browserInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Standalone script: No download; the skill invokes .claude/tools/chrome-browser/chrome-browser.cjs (Node.js v18+ required).
MCP integrations (for full automation):
--chrome when needed.Testing: Test user-visible behavior, not implementation. Isolate tests (own storage/cookies); use before/after hooks for login or setup. Mock third-party networks instead of depending on live services.
DevTools Recorder: Record flows in Recorder panel; export as JSON or test scripts (Puppeteer, Nightwatch). Replay with Puppeteer Replay in CI. Use for performance measurement of user flows.
Hacks: Prefer Chrome DevTools MCP for testing/debugging (always on); use Claude-in-Chrome for authenticated sessions (GIF, forms). Limit GIF frames (e.g. 100) to avoid memory issues. Use take_snapshot for structure; evaluate_script for custom checks.
No official cert. Chrome for Developers – DevTools. Frontend Masters / Udemy “Mastering Chrome DevTools.” Skill data: Test user-visible behavior; isolate tests; Recorder + Puppeteer Replay; performance tracing.
Suggested hooks: Optional: post-test hook to capture screenshots on failure. Use when qa or frontend-pro is routed for browser testing (add chrome-browser to contextual: browser_testing or similar).
Workflows: Use with qa (add to contextual) or frontend-pro for E2E/browser flows. Flow: open URL → interact (click/fill) → snapshot or assert. See .claude/workflows/chrome-browser-skill-workflow.md.
| Feature | Chrome DevTools MCP | Claude-in-Chrome |
| ------------------------ | ------------------------------- | ------------------------------ |
| Status | ✅ Always available | ⚠️ Requires --chrome flag |
| Activation | Automatic (built-in) | claude --chrome + extension |
| Auth sessions | ❌ Fresh browser | ✅ Uses your logins |
| Performance tracing | ✅ Full Core Web Vitals | ❌ Not available |
| Network inspection | ✅ Detailed with body access | ✅ Basic |
| Device emulation | ✅ Mobile, geolocation, CPU | ❌ Limited |
| GIF recording | ❌ No | ✅ Yes (100 frame limit) |
| Page text extraction | Via snapshot | ✅ Dedicated tool |
| Best for | Testing, debugging, performance | Authenticated workflows, demos |
Chrome browser automation can record GIF videos. To prevent memory exhaustion:
Frame tracking:
Need to test/debug a public site? → Chrome DevTools MCP
Need performance analysis? → Chrome DevTools MCP
Need to access authenticated apps? → Claude-in-Chrome (--chrome)
Need to record a demo GIF? → Claude-in-Chrome (--chrome)
Need to interact with Google Docs? → Claude-in-Chrome (--chrome)
Need device/network emulation? → Chrome DevTools MCP
<capabilities>
**Chrome DevTools MCP:**
- Page navigation and tab management
- Element interaction (click, fill, hover, drag)
- JavaScript execution in page context
- Console message monitoring
- Network request inspection with body access
- Performance tracing with Core Web Vitals
- Device emulation (mobile, geolocation, CPU throttling)
- Screenshot capture
- Dialog handling (alert, confirm, prompt)
Claude-in-Chrome:
No setup required - these tools work immediately.
// List all open pages
mcp__chrome - devtools__list_pages();
// Select a page to work with
mcp__chrome - devtools__select_page({ pageId: 1 });
// Create a new page
mcp__chrome - devtools__new_page({ url: 'https://example.com' });
// Navigate to URL
mcp__chrome - devtools__navigate_page({ url: 'https://example.com' });
// Take accessibility snapshot (get element UIDs)
mcp__chrome - devtools__take_snapshot();
// Click element by UID from snapshot
mcp__chrome - devtools__click({ uid: 'ref_123' });
// Fill form field
mcp__chrome - devtools__fill({ uid: 'ref_456', value: '[email protected]' });
// Fill entire form
mcp__chrome -
devtools__fill_form({
elements: [
{ uid: 'ref_456', value: '[email protected]' },
{ uid: 'ref_789', value: 'password123' },
],
});
// Read console messages
mcp__chrome - devtools__list_console_messages({ types: ['error', 'warn'] });
// Get specific console message details
mcp__chrome - devtools__get_console_message({ msgid: 1 });
// List network requests
mcp__chrome - devtools__list_network_requests({ resourceTypes: ['xhr', 'fetch'] });
// Get request/response details
mcp__chrome - devtools__get_network_request({ reqid: 1 });
// Execute JavaScript
mcp__chrome -
devtools__evaluate_script({
function: '() => document.title',
});
// Start performance trace (with page reload)
mcp__chrome - devtools__performance_start_trace({ reload: true, autoStop: true });
// Or manual stop
mcp__chrome - devtools__performance_start_trace({ reload: true, autoStop: false });
// ... interact with page ...
mcp__chrome - devtools__performance_stop_trace();
// Analyze specific insight
mcp__chrome -
devtools__performance_analyze_insight({
insightSetId: 'navigation-1',
insightName: 'LCPBreakdown',
});
// Emulate mobile device
mcp__chrome -
devtools__emulate({
viewport: {
width: 375,
height: 667,
deviceScaleFactor: 2,
isMobile: true,
hasTouch: true,
},
userAgent: 'Mozilla/5.0 (iPhone; CPU iPhone OS 16_0 like Mac OS X)...',
});
// Emulate slow network
mcp__chrome - devtools__emulate({ networkConditions: 'Slow 3G' });
// Emulate geolocation
mcp__chrome -
devtools__emulate({
geolocation: { latitude: 37.7749, longitude: -122.4194 },
});
claude --chrome// ALWAYS call first to get available tabs
mcp__claude-in-chrome__tabs_context_mcp({ createIfEmpty: true })
// Create a new tab for this conversation
mcp__claude-in-chrome__tabs_create_mcp()
// Navigate to URL
mcp__claude-in-chrome__navigate({ url: "https://docs.google.com", tabId: 123 })
// Read page structure (accessibility tree)
mcp__claude-in-chrome__read_page({ tabId: 123 })
// Find elements by natural language
mcp__claude-in-chrome__find({ query: "login button", tabId: 123 })
// Extract page text
mcp__claude-in-chrome__get_page_text({ tabId: 123 })
// Click, type, screenshot via computer tool
mcp__claude-in-chrome__computer({
action: "left_click",
coordinate: [100, 200],
tabId: 123
})
mcp__claude-in-chrome__computer({
action: "type",
text: "Hello world",
tabId: 123
})
mcp__claude-in-chrome__computer({
action: "screenshot",
tabId: 123
})
// Fill form by element reference
mcp__claude-in-chrome__form_input({
ref: "ref_1",
value: "[email protected]",
tabId: 123
})
// Start recording
mcp__claude-in-chrome__gif_creator({ action: "start_recording", tabId: 123 })
// Take screenshot to capture initial state
mcp__claude-in-chrome__computer({ action: "screenshot", tabId: 123 })
// ... perform actions ...
// Take final screenshot
mcp__claude-in-chrome__computer({ action: "screenshot", tabId: 123 })
// Stop and export
mcp__claude-in-chrome__gif_creator({ action: "stop_recording", tabId: 123 })
mcp__claude-in-chrome__gif_creator({
action: "export",
download: true,
filename: "demo.gif",
tabId: 123
})
✓ GOOD patterns:
✗ BAD patterns:
If you hit 100 frames:
</execution_process>
<best_practices>
</best_practices> </instructions>
<examples> <usage_example> **Test Login Flow (Chrome DevTools MCP)**:// Create page and navigate
mcp__chrome - devtools__new_page({ url: 'https://example.com/login' });
// Take snapshot to get element UIDs
mcp__chrome - devtools__take_snapshot();
// Fill login form
mcp__chrome -
devtools__fill_form({
elements: [
{ uid: 'email_field', value: '[email protected]' },
{ uid: 'password_field', value: 'testpass123' },
],
});
// Click submit
mcp__chrome - devtools__click({ uid: 'submit_button' });
// Check for errors
mcp__chrome - devtools__list_console_messages({ types: ['error'] });
</usage_example>
<usage_example> Performance Audit (Chrome DevTools MCP):
// Navigate to page
mcp__chrome - devtools__navigate_page({ url: 'https://example.com' });
// Run performance trace with reload
mcp__chrome -
devtools__performance_start_trace({
reload: true,
autoStop: true,
filePath: 'trace.json.gz',
});
// Analyze LCP breakdown
mcp__chrome -
devtools__performance_analyze_insight({
insightSetId: 'navigation-1',
insightName: 'LCPBreakdown',
});
</usage_example>
<usage_example> Google Docs Editing (Claude-in-Chrome):
// Get tab context
mcp__claude-in-chrome__tabs_context_mcp({ createIfEmpty: true })
// Navigate to Google Docs (uses your login)
mcp__claude-in-chrome__navigate({
url: "https://docs.google.com/document/d/YOUR_DOC_ID",
tabId: 123
})
// Read page to find elements
mcp__claude-in-chrome__read_page({ tabId: 123 })
// Click in document and type
mcp__claude-in-chrome__computer({
action: "left_click",
ref: "document_body",
tabId: 123
})
mcp__claude-in-chrome__computer({
action: "type",
text: "Meeting notes for today...",
tabId: 123
})
</usage_example>
<usage_example> Record Demo GIF (Claude-in-Chrome):
// Start recording
mcp__claude-in-chrome__gif_creator({ action: "start_recording", tabId: 123 })
// Initial screenshot
mcp__claude-in-chrome__computer({ action: "screenshot", tabId: 123 })
// Navigate
mcp__claude-in-chrome__navigate({ url: "https://example.com/product", tabId: 123 })
mcp__claude-in-chrome__computer({ action: "screenshot", tabId: 123 })
// Click add to cart
mcp__claude-in-chrome__computer({ action: "left_click", ref: "add_to_cart", tabId: 123 })
mcp__claude-in-chrome__computer({ action: "screenshot", tabId: 123 })
// Stop and export
mcp__claude-in-chrome__gif_creator({ action: "stop_recording", tabId: 123 })
mcp__claude-in-chrome__gif_creator({
action: "export",
download: true,
filename: "add-to-cart-flow.gif",
options: { showClickIndicators: true, showProgressBar: true },
tabId: 123
})
</usage_example> </examples>
| Tool | Description |
| --------------------------------------------------- | -------------------------------- |
| mcp__chrome-devtools__list_pages | List all browser pages |
| mcp__chrome-devtools__select_page | Select page for operations |
| mcp__chrome-devtools__new_page | Create new page with URL |
| mcp__chrome-devtools__close_page | Close a page |
| mcp__chrome-devtools__navigate_page | Navigate, reload, back/forward |
| mcp__chrome-devtools__take_snapshot | Get accessibility tree with UIDs |
| mcp__chrome-devtools__take_screenshot | Capture page/element screenshot |
| mcp__chrome-devtools__click | Click element by UID |
| mcp__chrome-devtools__fill | Fill input/select by UID |
| mcp__chrome-devtools__fill_form | Fill multiple form elements |
| mcp__chrome-devtools__hover | Hover over element |
| mcp__chrome-devtools__drag | Drag element to another |
| mcp__chrome-devtools__press_key | Press key or combination |
| mcp__chrome-devtools__evaluate_script | Execute JavaScript |
| mcp__chrome-devtools__handle_dialog | Accept/dismiss dialogs |
| mcp__chrome-devtools__upload_file | Upload file via input |
| mcp__chrome-devtools__wait_for | Wait for text to appear |
| mcp__chrome-devtools__resize_page | Resize browser window |
| mcp__chrome-devtools__emulate | Device/network/geo emulation |
| mcp__chrome-devtools__list_console_messages | List console output |
| mcp__chrome-devtools__get_console_message | Get message details |
| mcp__chrome-devtools__list_network_requests | List network requests |
| mcp__chrome-devtools__get_network_request | Get request/response details |
| mcp__chrome-devtools__performance_start_trace | Start performance recording |
| mcp__chrome-devtools__performance_stop_trace | Stop performance recording |
| mcp__chrome-devtools__performance_analyze_insight | Analyze performance insight |
--chrome flag)| Tool | Description |
| ---------------------------------------------- | ------------------------------- |
| mcp__claude-in-chrome__tabs_context_mcp | Get tab context (call first!) |
| mcp__claude-in-chrome__tabs_create_mcp | Create new tab |
| mcp__claude-in-chrome__navigate | Navigate to URL |
| mcp__claude-in-chrome__read_page | Get accessibility tree |
| mcp__claude-in-chrome__find | Find elements by description |
| mcp__claude-in-chrome__get_page_text | Extract page text |
| mcp__claude-in-chrome__computer | Click, type, screenshot, scroll |
| mcp__claude-in-chrome__form_input | Fill form field |
| mcp__claude-in-chrome__fill_form | Fill multiple fields |
| mcp__claude-in-chrome__javascript_tool | Execute JavaScript |
| mcp__claude-in-chrome__read_console_messages | Read console logs |
| mcp__claude-in-chrome__read_network_requests | Read network requests |
| mcp__claude-in-chrome__resize_window | Resize browser window |
| mcp__claude-in-chrome__upload_image | Upload image to element |
| mcp__claude-in-chrome__gif_creator | Record/export GIF |
| mcp__claude-in-chrome__shortcuts_list | List available shortcuts |
| mcp__claude-in-chrome__shortcuts_execute | Execute shortcut |
| mcp__claude-in-chrome__update_plan | Present plan for approval |
This skill is automatically assigned to:
For guidance on using this skill effectively, see the corresponding workflow:
.claude/workflows/chrome-browser-skill-workflow.md/chrome-browser)Two Integration Options:
--chrome flag) - For authenticated app workflows, GIF recordingThe workflow provides examples for invocation methods, agent assignment, and memory integration patterns.
Symptom: When using --chrome flag, tools return "Browser extension is not connected" error despite extension being installed.
Root Cause: Claude.app (desktop) and Claude Code register competing native messaging hosts. When both are installed, the Chrome extension connects to whichever registered last, causing connection failures.
Diagnosis:
%APPDATA%\Claude\ChromeNativeHost\com.anthropic.claude_browser_extension.json~/Library/Application Support/Claude/ChromeNativeHost/Known Bug: This is documented in GitHub issues:
Workaround (macOS):
# Disable Claude.app's native host (keep file for restoration)
cd ~/Library/Application\ Support/Google/Chrome/NativeMessagingHosts/
mv com.anthropic.claude_browser_extension.json com.anthropic.claude_browser_extension.json.disabled
# Restart Chrome completely (quit and reopen)
# Then start Claude Code with --chrome flag
Workaround (Windows): Not fully documented. Potential approach:
# Rename the config to disable Claude.app's registration
cd $env:APPDATA\Claude\ChromeNativeHost
ren com.anthropic.claude_browser_extension.json com.anthropic.claude_browser_extension.json.disabled
# Restart Chrome and try again
Alternative: Use Chrome DevTools MCP instead - it works without the extension and provides similar functionality for most use cases.
Symptom: After triggering alert/confirm/prompt, all browser tools stop responding.
Cause: JavaScript modal dialogs block all browser events including extension communication.
Fix: User must manually dismiss the dialog in the browser. Avoid triggering dialogs in automation scripts.
Before starting:
cat .claude/context/memory/learnings.md
After completing:
.claude/context/memory/learnings.md.claude/context/memory/issues.md.claude/context/memory/decisions.mdASSUME INTERRUPTION: Your context may reset. If it's not in memory, it didn't happen.
tools
Comprehensive biosignal processing toolkit for analyzing physiological data including ECG, EEG, EDA, RSP, PPG, EMG, and EOG signals. Use this skill when processing cardiovascular signals, brain activity, electrodermal responses, respiratory patterns, muscle activity, or eye movements. Applicable for heart rate variability analysis, event-related potentials, complexity measures, autonomic nervous system assessment, psychophysiology research, and multi-modal physiological signal integration.
tools
Comprehensive toolkit for creating, analyzing, and visualizing complex networks and graphs in Python. Use when working with network/graph data structures, analyzing relationships between entities, computing graph algorithms (shortest paths, centrality, clustering), detecting communities, generating synthetic networks, or visualizing network topologies. Applicable to social networks, biological networks, transportation systems, citation networks, and any domain involving pairwise relationships.
data-ai
Molecular featurization for ML (100+ featurizers). ECFP, MACCS, descriptors, pretrained models (ChemBERTa), convert SMILES to features, for QSAR and molecular ML.
development
Run Python code in the cloud with serverless containers, GPUs, and autoscaling. Use when deploying ML models, running batch processing jobs, scheduling compute-intensive tasks, or serving APIs that require GPU acceleration or dynamic scaling.