DroidPilot
Provides tools to control an Android device via ADB and UIAutomator, enabling AI agents to interact with native apps—tapping, typing, swiping, taking screenshots, and reading UI elements.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@DroidPilotLaunch Clock app, wait for 'Alarm', then screenshot"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
DroidPilot
Drive an Android phone over ADB + UIAutomator and expose it to an AI agent over MCP — Playwright-style, for native-app user testing.
The idea: while you build an Android app with Claude Code on your computer, that same Claude can drive your phone to run the user tests — tap, type, read the screen, and assert outcomes — by calling DroidPilot's tools over MCP. DroidPilot is the hands and eyes; Claude is the brain.
Claude Code (your computer, the test agent)
│ MCP (stdio)
▼
DroidPilot MCP server ──► adb / UIAutomator ──► Android phone (USB)
tap · type · swipe · screenshot · dump UI · wait · assertRequirements
Python 3.10+
adb (Android platform-tools) on PATH or under
ANDROID_HOME/the default SDKA phone with USB debugging enabled and authorized (unavoidable for controlling taps — unlike screen mirroring, driving the device needs adb)
Related MCP server: scrcpy-mcp
Install
pip install -e . # from a clone
# or: pip install git+https://github.com/LioMatthys/droidpilotUse it three ways
1. With Claude Code (the point) — MCP
Register the server once:
claude mcp add droidpilot -- droidpilot-mcp
# (equivalently: claude mcp add droidpilot -- python -m droidpilot.mcp_server)Then just ask Claude Code, e.g.:
Plug-in check: my phone is connected. Test that Beam (
life.overture.beam) shows a 6-digit code after I start sharing. Launch it, start sharing, accept the capture prompt, and confirm a code appears — screenshot the result.
Claude will call screen / screenshot to see the phone, tap_text / type_text to
act, and assert_text to verify — running the test like a human would.
2. As a CLI (manual / smoke testing)
droidpilot devices
droidpilot launch life.overture.beam
droidpilot screen # list on-screen elements
droidpilot tap-text "Start sharing"
droidpilot screenshot out.png
droidpilot assert-text "Code"3. As a Python library (scripted tests)
from droidpilot import Device
dev = Device(); dev.connect()
dev.launch_app("life.overture.beam")
dev.wait_for_text("Beam", timeout=15)
dev.tap_text("Start sharing")
dev.assert_text("Code")
dev.screenshot("beam.png")See examples/test_beam_flow.py.
MCP tools
Tool | What it does |
| connected devices + state |
| start/stop an app |
| compact text list of on-screen elements (label, tap point, id) |
| PNG of the current screen (visual inspection) |
| tap by coordinates or by element text |
| type into the focused field |
| back / home / enter / … or a raw |
| up / down / left / right |
| wait for an element to appear |
| pass/fail check that text is on screen |
|
|
screen() (cheap text) + screenshot() (image) give the agent both a structured and a
visual view; it usually picks targets from screen() and uses tap_text.
Limits (v0.1)
One device at a time (pass a serial to target a specific one).
System dialogs are localized — "Start now" vs "Démarrer maintenant". The agent reads the screen, so it adapts; scripted tests should match your device locale.
No video recording yet; screenshots only.
type_textescapes spaces/specials foradb shell input; exotic Unicode may not type.
Why not Appium/Maestro?
Both are great, but heavier (a server + drivers, or YAML flows). DroidPilot is a thin, agent-shaped surface: a handful of tools an LLM can call directly, built on the same ADB/UIAutomator primitives Google ships. Use Appium/Maestro for big scripted suites; use DroidPilot when you want Claude to test the app for you.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/LioMatthys/droidpilot'
If you have feedback or need assistance with the MCP directory API, please join our Discord server