Model Context Protocol server for Quash - AI-powered mobile automation agent
Project description
Quash MCP - AI-Powered Mobile Automation
A Model Context Protocol (MCP) server for mobile automation testing with Quash. Control Android devices and run automated tests from any MCP-compatible host using natural language.
Features
- ๐ค AI-Powered Automation: Control your Android device using plain English
- ๐ฑ Device Connection: Works with emulators and physical devices
- โ๏ธ Flexible Configuration: Customize AI model, temperature, vision, reasoning, and more
- ๐ Real-Time Execution: Live progress streaming during task execution
- ๐ฏ Suite Execution: Run multiple tasks in sequence with retry logic
- ๐ Usage Tracking: Monitor API costs and token usage
- ๐ Secure: API key authentication via Quash platform
Installation
pip install quash-mcp
All dependencies (including ADB tools and device connectivity) are automatically installed. AI execution happens on the Quash backend, keeping the client lightweight and proprietary logic protected.
Quick Start
1. Get Your API Key
- Visit quashbugs.com/mcp (or your deployment URL)
- Sign in with Google
- Go to Dashboard โ API Keys
- Create a new API key
2. Add to Your MCP Host
Quash MCP works with any MCP-compatible host. Configure it to use python3 -m quash_mcp which works across all Python environments:
Manual Configuration (Recommended)
Add to your MCP host's config file:
Config file locations:
- Claude Desktop (macOS):
~/Library/Application Support/Claude/claude_desktop_config.json - Claude Desktop (Linux):
~/.config/claude/claude_desktop_config.json - Claude Desktop (Windows):
%APPDATA%\Claude\claude_desktop_config.json - Claude Code:
~/.claude.json(project-specific underprojects.<path>.mcpServers)
{
"mcpServers": {
"quash": {
"command": "python3",
"args": ["-m", "quash_mcp"]
}
}
}
Why python3 -m quash_mcp?
- Works in any Python environment (conda, venv, system)
- No PATH configuration needed
- Uses whichever Python has quash-mcp installed
CLI Configuration (If Supported by Host)
Some MCP hosts might provide a command-line interface to add servers.
Examples:
-
Claude Code:
claude mcp add quash quash-mcp
-
Gemini CLI:
gemini mcp add quash quash-mcp
Alternative: Direct Command (if in PATH)
If quash-mcp is in your PATH:
{
"mcpServers": {
"quash": {
"command": "quash-mcp"
}
}
}
Then restart your MCP host.
3. Start Automating
Ask your AI assistant (via your MCP host):
"Setup Quash and connect to my Android device"
"Configure with my API key: mhg_xxxx..."
"Execute task: Open Settings and enable WiFi"
Available Tools
1. build
Setup and verify all dependencies.
Example:
Can you run the build tool to setup my system for Quash?
2. connect
Connect to an Android device or emulator.
Parameters:
device_serial(optional): Device serial number
Example:
Connect to my Android device
3. configure
Configure agent execution parameters.
Parameters:
quash_api_key: Your Quash API key from the web portalmodel: LLM model (e.g., "anthropic/claude-sonnet-4", "openai/gpt-4o")temperature: 0-2 (default: 0.2)max_steps: Maximum execution steps (default: 15)vision: Enable screenshots (default: false)reasoning: Enable multi-step planning (default: false)reflection: Enable self-improvement (default: false)debug: Verbose logging (default: false)
Example:
Configure Quash with my API key mhg_xxx, use Claude Sonnet 4, and enable vision
4. execute
Run an automation task on the device.
Parameters:
task: Natural language task description
Example:
Execute task: Open Settings and navigate to WiFi settings
5. runsuite
Execute multiple tasks in sequence with retry logic.
Parameters:
suite_name: Name of the test suitetasks: Array of tasks with retry and failure handling options
Example:
Run a test suite with these tasks: [
{"prompt": "Open Settings", "type": "setup"},
{"prompt": "Enable WiFi", "type": "test", "retries": 2},
{"prompt": "Close Settings", "type": "teardown"}
]
6. usage
View API usage statistics and costs.
Example:
Show me my Quash usage statistics
Complete Workflow Example
User: "Setup Quash on my machine"
โ Runs build tool
โ Returns: All dependencies installed โ
User: "Connect to my Android emulator"
โ Runs connect tool
โ Returns: Connected to emulator-5554 โ
User: "Configure to use Claude Sonnet 4 with vision and my API key is mhg_xxx..."
โ Runs configure tool
โ Returns: Configuration set โ
User: "Execute task: Open Instagram and go to my profile"
โ Runs execute tool with live streaming
โ Returns: Task completed โ
User: "Show me my usage statistics"
โ Runs usage tool
โ Returns: Total cost: $0.15, 10 executions โ
Requirements
- Python 3.11+ - Required for the MCP server
- Android Device - Emulator or physical device with USB debugging enabled
- Quash API Key - Get from quashbugs.com/mcp
Dependencies automatically installed:
- Android Debug Bridge (ADB) - via
adbutils - Quash Portal APK - via
apkutils - MCP protocol support - via
mcp - HTTP client - via
httpx
Architecture
v0.2.0 uses a client-server architecture:
- Client (quash-mcp): Lightweight MCP server handling device connections and API calls
- Server (Quash backend): Proprietary AI execution engine (LLMs, agents, pricing logic)
quash-mcp/
โโโ quash_mcp/
โ โโโ __main__.py # Module entry point for python -m
โ โโโ server.py # Main MCP server entry point
โ โโโ backend_client.py # API communication with Quash backend
โ โโโ state.py # Session state management
โ โโโ tools/
โ โโโ build.py # Dependency checker and installer
โ โโโ connect.py # Device connectivity
โ โโโ configure.py # Agent configuration
โ โโโ execute.py # Task execution (calls backend API)
โ โโโ runsuite.py # Suite execution (calls backend API)
โ โโโ usage.py # Usage statistics (from backend)
โโโ pyproject.toml
Troubleshooting
"No devices found"
- Start Android emulator via Android Studio > AVD Manager
- Connect physical device with USB debugging enabled
- For WiFi debugging:
adb tcpip 5555 && adb connect <device-ip>:5555
"Portal not ready"
- The
connecttool automatically installs the Portal APK - If it fails, manually enable the Quash Portal accessibility service in Settings > Accessibility
"Invalid API key"
- Make sure you've run
configurewith a valid API key from quashbugs.com - API keys start with
mhg_prefix - Check your API key hasn't been revoked in the web portal
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file quash_mcp-1.0.0.tar.gz.
File metadata
- Download URL: quash_mcp-1.0.0.tar.gz
- Upload date:
- Size: 30.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dc9520f8fae5c5e7f75b43b09714b6ea9ecf46f24d598f071c8ff8525335a53b
|
|
| MD5 |
673f831b6cbf27d3dd3bb29a143fc2ae
|
|
| BLAKE2b-256 |
d070f319968d3422922e880b75ad68b2b078e1e3470b6afda452e941c1e6edb6
|
File details
Details for the file quash_mcp-1.0.0-py3-none-any.whl.
File metadata
- Download URL: quash_mcp-1.0.0-py3-none-any.whl
- Upload date:
- Size: 36.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb07389f8d7a98ac3460f62e4edd07dc47e6eee06aa807daf80ae498af273150
|
|
| MD5 |
5b8b9e49a42a5f87e8a6d072eef34c5a
|
|
| BLAKE2b-256 |
599de7837cb9c9a19a12a76a6a3459c77149b2f491082bed2f215961f1684e39
|