https://github.com/steve228uk/metro-mcp
🚇 A plugin-based MCP server for React Native runtime debugging, inspection, and automation. Connects to Metro bundler via Chrome DevTools Protocol — no app code changes needed for most features.
https://github.com/steve228uk/metro-mcp
agentic-ai cdp chrome-devtools-protocol debugger debugging expo hermes llm mcp mcp-server react-native
Last synced: about 1 month ago
JSON representation
🚇 A plugin-based MCP server for React Native runtime debugging, inspection, and automation. Connects to Metro bundler via Chrome DevTools Protocol — no app code changes needed for most features.
- Host: GitHub
- URL: https://github.com/steve228uk/metro-mcp
- Owner: steve228uk
- License: mit
- Created: 2026-03-27T23:14:23.000Z (about 2 months ago)
- Default Branch: main
- Last Pushed: 2026-04-03T18:52:19.000Z (about 2 months ago)
- Last Synced: 2026-04-03T20:48:23.655Z (about 2 months ago)
- Topics: agentic-ai, cdp, chrome-devtools-protocol, debugger, debugging, expo, hermes, llm, mcp, mcp-server, react-native
- Language: TypeScript
- Homepage: https://metromcp.dev/
- Size: 887 KB
- Stars: 6
- Watchers: 1
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# metro-mcp
[](https://vscode.dev/redirect/mcp/install?name=metro-mcp&config=%7B%22command%22%3A%22npx%22%2C%22args%22%3A%5B%22-y%22%2C%22metro-mcp%22%5D%2C%22env%22%3A%7B%7D%7D)
[](https://cursor.com/en/install-mcp?name=metro-mcp&config=eyJjb21tYW5kIjoibnB4IiwiYXJncyI6WyIteSIsIm1ldHJvLW1jcCJdLCJlbnYiOnt9fQ==)
A plugin-based MCP server for React Native runtime debugging, inspection, and automation. Connects to Metro bundler via Chrome DevTools Protocol — **no app code changes needed** for most features.
Works with **Expo**, **bare React Native**, and any project using **Metro + Hermes**.
---
## Contents
- [Quick Start](#quick-start)
- [Requirements](#requirements)
- [How It Works](#how-it-works)
- [Features](#features)
- [Chrome DevTools](#chrome-devtools)
- [Claude Code Status Bar](#claude-code-status-bar)
- [Test Recording](#test-recording)
- [App Integration](#app-integration-optional)
- [Configuration](#configuration)
- [Custom Plugins](#custom-plugins)
- [Compatibility](#compatibility)
---
## Quick Start
### Claude Code
```bash
claude mcp add metro-mcp -- npx -y metro-mcp
# or with Bun
claude mcp add metro-mcp -- bunx metro-mcp
```
### Cursor / VS Code
```json
{
"mcpServers": {
"metro-mcp": {
"command": "npx",
"args": ["-y", "metro-mcp"]
}
}
}
```
Or with Bun:
```json
{
"mcpServers": {
"metro-mcp": {
"command": "bunx",
"args": ["metro-mcp"]
}
}
}
```
### With custom Metro port
```bash
claude mcp add metro-mcp -- npx -y metro-mcp --port 19000
```
---
## Requirements
- **Node.js** 18+ or **Bun** 1.0+
- **iOS**: Xcode 14+ with Simulator (`xcrun simctl` is used for most operations)
- **Android**: Android SDK with `adb` on your PATH
- **IDB** *(optional)*: Some iOS operations fall back to [IDB (idb-companion)](https://github.com/facebook/idb) — install with `brew install idb-companion`. Tools will tell you when IDB is needed.
---
## How It Works
metro-mcp connects to your running Metro dev server the same way Chrome DevTools does:
1. Discovers Metro via port scanning (8081, 8082, 19000–19002)
2. Connects to Hermes via Chrome DevTools Protocol (CDP)
3. Streams console logs, network requests, and errors into buffers
4. Exposes everything as MCP tools, resources, and prompts
**No app modifications required** for core debugging features.
---
## Features
| Plugin | Tools | Description |
|--------|-------|-------------|
| **console** | 2 | Console log collection with filtering |
| **network** | 6 | Network request tracking, response body inspection, and stats |
| **errors** | 3 | Runtime exception collection + Metro bundle error detection |
| **evaluate** | 1 | Execute JavaScript in the app runtime |
| **device** | 4 | Device management, connection status, and app reload |
| **source** | 1 | Stack trace symbolication |
| **redux** | 3 | Redux state inspection and action dispatch |
| **components** | 5 | React component tree inspection |
| **storage** | 3 | AsyncStorage reading |
| **simulator** | 6 | iOS simulator / Android device control |
| **deeplink** | 2 | Cross-platform deep link testing |
| **ui-interact** | 6 | UI automation (tap, swipe, type) |
| **navigation** | 4 | React Navigation / Expo Router state |
| **accessibility** | 3 | Accessibility auditing |
| **commands** | 2 | Custom app commands |
| **automation** | 3 | Wait/polling helpers for async state changes |
| **profiler** | 9 | CPU profiling (React DevTools hook) + heap sampling + render tracking |
| **test-recorder** | 7 | Record interactions and generate Appium, Maestro, or Detox tests |
| **devtools** | 1 | Open Chrome DevTools alongside the MCP via CDP proxy |
| **debug-globals** | 1 | Auto-discover Redux stores, Apollo Client, and other debug globals |
| **inspect-point** | 1 | Coordinate-based React component inspection (experimental) |
| **statusline** | 1 | Claude Code status bar integration |
→ See the [full tools reference](docs/tools.md).
---
## Chrome DevTools
Hermes (the React Native JavaScript engine) only allows a **single CDP debugger connection** at a time. Since metro-mcp uses that connection, pressing **"j" in Metro** or tapping **"Open Debugger"** in the dev menu will steal the connection and disconnect the MCP.
metro-mcp solves this with a built-in **CDP proxy** that multiplexes the single Hermes connection, allowing Chrome DevTools and the MCP to work simultaneously.
### Opening DevTools
Use the `open_devtools` MCP tool instead of the usual methods. It opens the same React Native DevTools frontend (rn_fusebox) that Metro uses, but routes the WebSocket connection through the proxy so both can coexist.
The tool automatically finds Chrome or Edge using the same detection as Metro and opens a standalone DevTools window.
### What to avoid
| Method | What happens |
|--------|-------------|
| Pressing **"j"** in Metro terminal | Disconnects the MCP |
| **"Open Debugger"** in the dev menu | Disconnects the MCP |
| `open_devtools` MCP tool | Works alongside the MCP |
### Configuration
The CDP proxy is enabled by default. To change the port or disable it:
```bash
# Set a fixed proxy port
METRO_MCP_PROXY_PORT=9222 npx metro-mcp
# Disable the proxy entirely
METRO_MCP_PROXY_ENABLED=false npx metro-mcp
```
---
## Claude Code Status Bar
Get live Metro CDP connection status in your Claude Code status bar.
Run `setup_statusline` in Claude Code — it writes a script to `~/.claude/metro-mcp-statusline.sh`, then ask Claude to add it to your status bar:
```
/statusline add the script at ~/.claude/metro-mcp-statusline.sh
```
The status bar segment shows three states:
| State | Display |
|-------|---------|
| Not running | `Metro ○` (dimmed) |
| Running, not connected | `Metro ●` (red) |
| Connected | `Metro ● localhost:8081` (green) |
---
## Test Recording
Record real user interactions (taps, text entry, scrolls) and generate production-ready tests — no app code changes required.
### AI-driven test generation
Describe a flow and the AI navigates the app, then generates the test:
> *"Write an Appium test for the guest checkout flow — start by tapping 'Start Shopping' on the welcome screen and end when the cart screen is visible."*
The AI calls `start_test_recording`, navigates using `tap_element`/`type_text`/`swipe`, then generates a complete test with real selectors observed from the fiber tree.
### Manual recording
```
start_test_recording → inject interceptors
(interact with the app)
stop_test_recording → retrieve event log
generate_test_from_recording format=appium
```
Supports **Appium (WebdriverIO)**, **Maestro YAML**, and **Detox**.
→ See the [testing guide](docs/testing.md) for full details, format examples, and tips.
---
## App Integration (Optional)
Register custom commands and expose state to the MCP server — no package needed. Add this to your app entry point in dev mode:
```typescript
if (__DEV__) {
globalThis.__METRO_BRIDGE__ = {
commands: {
// Run custom actions from the MCP client
login: async ({ email, password }) => {
return await authService.login(email, password);
},
resetOnboarding: () => {
AsyncStorage.removeItem('onboarding_completed');
},
switchUser: ({ userId }) => {
store.dispatch(switchUser(userId));
},
},
state: {
// Expose state snapshots readable via get_redux_state
userStore: () => useUserStore.getState(),
},
};
}
```
Use `list_commands` and `run_command` to call these from the MCP client.
For enhanced features like real-time Redux action tracking, navigation events, performance marks, and React render profiling, install [`metro-bridge`](https://www.npmjs.com/package/metro-bridge) — see the [client SDK docs](docs/sdk.md) and [profiling guide](docs/profiling.md).
---
## Configuration
See [configuration docs](docs/configuration.md) for environment variables, CLI arguments, and config file options.
---
## Custom Plugins
metro-mcp is fully extensible. See the [plugins guide](docs/plugins.md) to build your own tools and resources.
---
## Compatibility
- **React Native**: 0.70+ (Hermes required)
- **Expo**: SDK 49+
- **Runtime**: Node.js 18+ or Bun 1.0+
- **Platforms**: iOS Simulator, Android Emulator, physical devices via USB
## License
MIT