Dotnet-skills dotnet-chrome-devtools-mcp
Use Chrome DevTools MCP from .NET agents and .NET-focused repos to inspect, debug, and automate Chrome through an MCP client.
install
source · Clone the upstream repo
git clone https://github.com/managedcode/dotnet-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/managedcode/dotnet-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/catalog/Tools/Chrome-DevTools-MCP/skills/dotnet-chrome-devtools-mcp" ~/.claude/skills/managedcode-dotnet-skills-dotnet-chrome-devtools-mcp && rm -rf "$T"
manifest:
catalog/Tools/Chrome-DevTools-MCP/skills/dotnet-chrome-devtools-mcp/SKILL.mdsource content
Chrome DevTools MCP for .NET Repos
Trigger On
- the repo needs browser-level debugging for ASP.NET Core, Blazor, WebAssembly, or any .NET app with a web UI
- the user wants an MCP server that can inspect console output, network traffic, screenshots, traces, and DOM state
- the repo needs agent-friendly browser control instead of manual DevTools work
Do Not Use For
- pure .NET code analysis, unit testing, or NuGet/package management
- static HTML linting alone
- sensitive browser sessions that must not be exposed to an MCP client
Inputs
- the nearest
AGENTS.md - the MCP client config for the current agent or app
- the target Chrome mode: launch new, connect to existing browser, or attach to a WebSocket endpoint
- the target app URL or local dev server
Workflow
- Choose the browser mode first.
- new ephemeral browser: default when you want a clean session
- existing browser: use
or--browserUrl--wsEndpoint - running browser with a user profile: use
only when Chrome 144+ and remote debugging are already enabled--autoConnect
- Prefer repo-local config over ad hoc shell commands.
- store the MCP server block in the repo or agent config so every run is repeatable
- Start from the smallest useful surface.
- use
when you only need navigation, JavaScript execution, and screenshots--slim - leave the full toolset enabled when you need network, performance, or emulation
- use
- Be explicit about privacy and cost.
- disable usage statistics or CrUX-backed performance enrichment when policy or sensitivity requires it
- Validate against the real app, not a mock page.
- use the app's local dev server, preview URL, or a production-like environment that reflects the bug
Install And Configure
Use the same JSON MCP server block in whatever .NET agent/app host you use:
{ "mcpServers": { "chrome-devtools": { "command": "npx", "args": ["-y", "chrome-devtools-mcp@latest"] } } }
Common variants:
{ "mcpServers": { "chrome-devtools": { "command": "npx", "args": ["-y", "chrome-devtools-mcp@latest", "--slim", "--headless"] } } }
{ "mcpServers": { "chrome-devtools": { "command": "npx", "args": ["-y", "chrome-devtools-mcp@latest", "--browserUrl", "http://127.0.0.1:9222"] } } }
For Codex CLI, the upstream repo documents:
codex mcp add chrome-devtools -- npx chrome-devtools-mcp@latest
Useful Flags
: three-tool surface for navigation, JavaScript execution, and screenshots only--slim
: run without UI--headless
or--browserUrl
: attach to an existing debuggable browser--wsEndpoint
: add custom WebSocket headers when--wsHeaders
is used--wsEndpoint
: connect to a locally running Chrome 144+ instance instead of launching a new one--autoConnect
: pick a Chrome channel--channel stable|beta|dev|canary
: create and clean up a temporary profile--isolated
: reuse a specific Chrome profile directory--userDataDir
: opt out of usage collection--no-usage-statistics
: stop sending performance trace URLs to CrUX--no-performance-crux
: only when the target environment uses self-signed or expired certs--acceptInsecureCerts
: capture debug logs for bug reports--logFile <path>
: only when ffmpeg is available and you need video capture--experimentalScreencast
Practical Usage Patterns
- Debug a local ASP.NET Core or Blazor app:
- start the app
- connect with
if the browser is already running, or let the server launch Chrome--browserUrl - ask the agent to inspect console errors, network failures, and rendering behavior
- Investigate a flaky UI test:
- use
--headless --isolated - capture screenshots and console logs from the failing route
- compare the result to a known-good run
- use
- Diagnose performance regressions:
- keep the full toolset enabled
- use performance tools only when you need trace data
- prefer
for quick smoke checks, not for performance work--slim
- Work in a sandboxed or containerized environment:
- attach to a running browser with
or--browserUrl--wsEndpoint - avoid assuming the server can launch Chrome itself
- attach to a running browser with
- Reuse a signed-in session:
- use
--userDataDir - avoid
--isolated - accept that this increases exposure to sensitive browser state
- use
flowchart LR A[".NET repo or app"] --> B["MCP-capable agent/app"] B --> C["chrome-devtools-mcp config"] C --> D["Chrome"] D --> E["Console / network / screenshots / traces"]
Risks And Tradeoffs
- The server can see and act on browser content, so do not point it at sensitive accounts or data unless that exposure is intended.
lowers token and tool overhead, but it removes network, performance, and emulation workflows.--slim
is safer for disposable runs, but it discards existing browser state and logins.--isolated
is convenient for local debugging, but it depends on Chrome 144+ and remote debugging being enabled.--autoConnect
and CrUX-backed performance traces may change what data leaves the machine; disable them when policy requires it.--no-usage-statistics
is good for CI or scripted runs, but it can hide UI-specific failures.--headless- Passing
or similar launch flags can be necessary in some container or root environments, but only use it when the environment really requires it.--chromeArg='--no-sandbox'
Handle Failures
- If
returns a permission denied error on macOS fromnpx
, clear_npx
and rerun.~/.npm/_npx - If the server cannot find Chrome, check
,--channel
, and whether Chrome is installed on the host.--executablePath - If connection to an existing browser fails, verify
and thehttp://127.0.0.1:9222/json/version
value.webSocketDebuggerUrl - If performance traces are noisy or too expensive, keep the browser mode stable and compare runs against the same URL and browser channel.
Validate
prints the expected flags on the current hostnpx -y chrome-devtools-mcp@latest --help- the MCP client can list the server and open a page in the target browser
- the agent can capture at least one screenshot or console/network observation from the real app
- the chosen mode matches the task:
for quick browser checks, full mode for debugging and performance--slim
Deliver
- a repeatable MCP server config for the repo or agent host
- a browser connection mode that fits the environment
- a safe default for privacy, performance, and reproducibility