Chrome-devtools-mcp chrome-devtools
Uses Chrome DevTools via MCP for efficient debugging, troubleshooting and browser automation. Use when debugging web pages, automating browser interactions, analyzing performance, or inspecting network requests. This skill does not apply to `--slim` mode (MCP configuration).
install
source · Clone the upstream repo
git clone https://github.com/ChromeDevTools/chrome-devtools-mcp
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ChromeDevTools/chrome-devtools-mcp "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/chrome-devtools" ~/.claude/skills/chromedevtools-chrome-devtools-mcp-chrome-devtools && rm -rf "$T"
manifest:
skills/chrome-devtools/SKILL.mdsource content
Core Concepts
Browser lifecycle: Browser starts automatically on first tool call using a persistent Chrome profile. Configure via CLI args in the MCP server configuration:
npx chrome-devtools-mcp@latest --help. To enable extensions, use --categoryExtensions.
Page selection: Tools operate on the currently selected page. Use list_pages to see available pages, then select_page to switch context.
Element interaction: Use
take_snapshot to get page structure with element uids. Each element has a unique uid for interaction. If an element isn't found, take a fresh snapshot - the element may have been removed or the page changed.
Workflow Patterns
Before interacting with a page
- Navigate:
ornavigate_pagenew_page - Wait:
to ensure content is loaded if you know what you look for.wait_for - Snapshot:
to understand page structuretake_snapshot - Interact: Use element
s from snapshot foruid
,click
, etc.fill
Efficient data retrieval
- Use
parameter for large outputs (screenshots, snapshots, traces)filePath - Use pagination (
,pageIdx
) and filtering (pageSize
) to minimize datatypes - Set
on input actions unless you need updated page stateincludeSnapshot: false
Tool selection
- Automation/interaction:
(text-based, faster, better for automation)take_snapshot - Visual inspection:
(when user needs to see visual state)take_screenshot - Additional details:
for data not in accessibility treeevaluate_script
Parallel execution
You can send multiple tool calls in parallel, but maintain correct order: navigate → wait → snapshot → interact.
Testing an extension
- Install: Use
with the path to the unpacked extension.install_extension - Identify: Get the extension ID from the response or by calling
.list_extensions - Trigger Action: Use
to open the popup or side panel if applicable.trigger_extension_action - Verify Service Worker: Use
withevaluate_script
to check extension state or trigger background actions.serviceWorkerId - Verify Page Behavior: Navigate to a page where the extension operates and use
to check if content scripts injected elements or modified the page correctly.take_snapshot
Troubleshooting
If
chrome-devtools-mcp is insufficient, guide users to use Chrome DevTools UI:
If there are errors launching
chrome-devtools-mcp or Chrome, refer to https://github.com/ChromeDevTools/chrome-devtools-mcp/blob/main/docs/troubleshooting.md.