HarmonyOS MCP service for device automation, app deployment, UI interaction, E2E support, and log validation.
Project description
HarmonyOS Dev MCP
harmonyos_dev_mcp provides HarmonyOS MCP tools for device discovery, app build and deployment, UI automation, E2E inspection, and log validation.
Links
- PyPI: harmonyos-dev-mcp
- Tool reference: docs/tool_reference.md
- Logs query guide: docs/logs_query.md
What It Provides
The package exposes 18 MCP tools:
Parameter notation:
name: requiredname?: optionalname*: conditionally required, depending on the selected mode or target
General tools:
| Tool | Parameters |
|---|---|
list_devices |
none |
query_package |
device_id?, bundle_name*, keyword?, info_type?="list" |
logs_query |
device_id?, logs?, input_file?, input_files?, lines?=100, level?, tag?, tag_search?, keyword?, domain?, pid?, package_name?, start_time?, end_time?, seconds?, save_path?, time_expr?, include_crash?=false, mode?="errors", marker_keywords?, fallback_to_historical?=false, realtime_wait_ms?=1000, context_lines?=0 |
Build tools:
| Tool | Parameters |
|---|---|
build_app |
project_path, build_mode?="debug", target?="hap", product?="default", module_name*, is_clean?=false, include_hsp?=false, hsp_module_names? |
install_app |
hap_path, device_id? |
run_app |
bundle_name, device_id?, ability_name?, module_name?, auto_detect?=true |
uninstall_app |
bundle_name, device_id? |
UI tools:
| Tool | Parameters |
|---|---|
screenshot |
device_id?, local_path?, display_id?=0, left*, top*, right*, bottom* |
click_element |
device_id?, x*, y*, element_handle*, text*, element_type*, element_id*, double_click?=false, bundle_name? |
long_press_element |
device_id?, x*, y*, element_handle*, text*, element_type*, element_id*, bundle_name? |
input_text |
device_id?, x*, y*, text, element_handle*, element_text*, element_type*, element_id*, bundle_name? |
swipe |
device_id?, from_x*, from_y*, to_x*, to_y*, direction*, speed?=600 |
drag |
device_id?, from_x, from_y, to_x, to_y, speed?=600 |
press_key |
device_id?, key |
find_element |
device_id?, text*, element_type*, element_id*, bundle_name?, window_id? |
E2E tools:
| Tool | Parameters |
|---|---|
get_ui_tree |
device_id?, bundle_name?, window_id? |
list_windows |
device_id?, bundle_name? |
wait_element |
device_id?, bundle_name?, window_id?, text*, element_type*, element_id*, state?="found", timeout_ms?=5000, interval_ms?=300 |
build_app supports HarmonyOS HAP, HAR, HSP, APP, and HNP build flows. HSP outputs can also be integrated into a HAP with include_hsp=true.
Detailed validation rules, result fields, errors, and examples are in the tool reference.
Layout
mcp_ho_dev/
|- src/harmonyos_dev_mcp/
| |- build/ # Hvigor build helpers, signing, packaging, and target handlers
| |- device/hdc/ # HDC device, package, app, file, and UI adapters
| |- logs/ # Log query parsing and history support
| |- runtime/ # Server factory and explicit MCP tool registration
| |- tools/ # Public MCP tool entrypoints
| |- ui/ # UI tree parsing, selectors, actions, and normalization
| |- utils/ # Compatibility wrappers
| `- _common/ # Shared runtime infrastructure bundled in this package
|- tests/unit/ # Unit tests grouped by domain
|- docs/ # Public tool and log query documentation
|- scripts/ # Release helpers
|- pyproject.toml # Project metadata and build config
|- uv.lock
|- README.md
Requirements
- Python 3.12+
- DevEco Studio 5.0+
- HarmonyOS SDK toolchains, including
hdc uv
Install
Install from PyPI:
pip install harmonyos-dev-mcp
Install from source for local development:
uv sync
Run
uv run harmonyos-dev-mcp
Check connected devices:
hdc list targets
Documentation
Build Examples
Build a debug HAP:
await build_app(r"C:\path\to\project", target="hap", build_mode="debug", product="default")
Build HSP modules and integrate them into a HAP:
await build_app(
r"C:\path\to\project",
target="hap",
build_mode="debug",
product="default",
include_hsp=True,
hsp_module_names=["library_one", "library_two"],
)
Build an HNP-injected HAP:
await build_app(r"C:\path\to\project", target="hnp", build_mode="debug", product="default")
Development
Run unit tests:
uv run pytest tests/unit -v
Run with coverage:
uv run pytest tests/unit -v --cov=harmonyos_dev_mcp
Build package artifacts:
uv build --out-dir dist --clear
Notes
build_appis a long-running tool. Set MCPtools/call timeoutto at least60s, and prefer120sfor cold builds.build_app target="hnp"builds a base HAP, injects module HNP packages fromentry/hnp, and signs the HAP through SDK packaging tools.build_app target="hsp"builds shared modules;build_app target="hap" include_hsp=truecan integrate one or more HSP outputs into the HAP.logs_querysupportserrorsandmarkersmodes.- The shared infrastructure that used to live in a separate common package is bundled in
harmonyos_dev_mcp._common.
License
Apache License 2.0
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 harmonyos_dev_mcp-0.8.1.tar.gz.
File metadata
- Download URL: harmonyos_dev_mcp-0.8.1.tar.gz
- Upload date:
- Size: 201.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.28 {"installer":{"name":"uv","version":"0.9.28","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7cd3ed7dfb708ce565c4519195273a22d381bc8d61225ff3a135e157b21a720b
|
|
| MD5 |
5674d4ed4358afcf0abd8348358e80a1
|
|
| BLAKE2b-256 |
e14ef97bef5ef5f54e368e061231947a0fcd36cf22c320c64687251f41d3e463
|
File details
Details for the file harmonyos_dev_mcp-0.8.1-py3-none-any.whl.
File metadata
- Download URL: harmonyos_dev_mcp-0.8.1-py3-none-any.whl
- Upload date:
- Size: 119.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.28 {"installer":{"name":"uv","version":"0.9.28","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ed819633f329360b02125a77d44c9ac335fec46398658a26e33ba15dd2c088b9
|
|
| MD5 |
70b8d5b8e65e4dc8db887d1331b3a6a1
|
|
| BLAKE2b-256 |
238c7eaef2761469aaa55c3120b407472874fbd7d9678dd289f7b66d401c4733
|