@chaixueyuan/weapp-agent-mcp
v0.3.1
Published
Agent-first MCP server for WeChat Mini Program debugging, automation, and lightweight testing
Maintainers
Readme
weapp-agent-mcp
weapp-agent-mcp 是一个面向 agent 的微信小程序 MCP 服务,基于 miniprogram-automator 封装微信开发者工具自动化能力,用于页面调试、元素操作、轻量回归测试与恢复友好型排查。
它适合:
- agent 主开发 / 主调试
- 串行截图与页面巡检
- 轻量 scenario / report
- 基于稳定 selector 的自动化验证
它当前不应被宣传为:
- 并发截图通道
- 超长高压全链路回归引擎
项目来源:本仓库基于上游
weapp-dev-mcp/@yfme/weapp-dev-mcp演进而来,当前以独立发布与 agent-first 体验为目标继续维护。
文档导航
更完整的文档入口见 docs/README.md。
前置要求
- 已安装微信开发者工具,支持命令行访问(
cli/cli.bat) - 本地已安装 Node.js 18+ 和
npm - 有可以在开发者工具中打开的小程序项目
- 已在微信开发者工具中开启自动化测试与服务端口
快速开始
方式一:通过 npm / npx 接入(推荐,普通用户默认这样用)
不需要先把仓库拉到本地,也不需要自己手动构建 dist。只要本机有 Node.js 和 npx,就可以直接在 MCP 客户端里这样配置:
{
"mcpServers": {
"weapp-agent-mcp": {
"command": "npx",
"args": [
"-y",
"@chaixueyuan/weapp-agent-mcp"
],
"env": {
"WEAPP_WS_ENDPOINT": "ws://localhost:9420"
}
}
}
}如果你希望在 Claude 等客户端里用更短的别名,也可以把 MCP server key 命名为
weapp-dev,但发布包名和服务名以weapp-agent-mcp为准。
可选:如果你习惯全局安装,也可以先执行:
npm install -g @chaixueyuan/weapp-agent-mcp然后把 MCP 配置改成:
{
"mcpServers": {
"weapp-agent-mcp": {
"command": "weapp-agent-mcp",
"env": {
"WEAPP_WS_ENDPOINT": "ws://localhost:9420"
}
}
}
}方式二:本地源码构建接入(仅开发者 / 贡献者)
只有在以下场景才需要这样用:
- 你正在开发这个仓库本身
- 你要调试尚未发布到 npm 的改动
- 你要在本地修改源码后立刻验证
npm install
npm run build
node dist/index.js{
"mcpServers": {
"weapp-agent-mcp": {
"command": "node",
"args": [
"/absolute/path/to/weapp-agent-mcp/dist/index.js"
],
"env": {
"WEAPP_WS_ENDPOINT": "ws://localhost:9420"
}
}
}
}本地开发
npm install
npm run dev重要边界
mp_screenshot当前按串行单通道能力设计,不支持并发压测- 复杂业务链建议拆成多个短 scenario,而不是一个超长 scenario
page_snapshot、mp_screenshot、长mp_runScenario在连续复杂操作后可能超时- 若出现连续失败,先运行
mp_healthCheck,必要时执行mp_recoverConnection - 稳定性高度依赖业务页面提供清晰的
qa-*selector 或其他稳定定位锚点
MCP 客户端集成
Claude Code 自动批准工具权限
由于使用 Claude Code 调用 MCP 工具时,会触发工具调用权限申请,此时可能会丢失 MCP 与微信开发者工具的连接状态,由于获取控制台输出高度依赖连接状态,此时会无法连贯的获取输出日志,所以建议手动添加权限:
在项目目录下创建 .claude/settings.local.json 文件,或在已有文件添加以下内容后即可免确认直接调用工具,或者根据需要添加您允许免确认调用的工具:
{
"permissions": {
"allow": [
"mcp__weapp-agent-mcp__mp_diagnoseConnection",
"mcp__weapp-agent-mcp__mp_ensureConnection",
"mcp__weapp-agent-mcp__mp_navigate",
"mcp__weapp-agent-mcp__mp_screenshot",
"mcp__weapp-agent-mcp__mp_callWx",
"mcp__weapp-agent-mcp__mp_evaluate",
"mcp__weapp-agent-mcp__mp_getLogs",
"mcp__weapp-agent-mcp__mp_currentPage",
"mcp__weapp-agent-mcp__mp_healthCheck",
"mcp__weapp-agent-mcp__mp_recoverConnection",
"mcp__weapp-agent-mcp__mp_listProjects",
"mcp__weapp-agent-mcp__mp_setDefaultProject",
"mcp__weapp-agent-mcp__page_getElement",
"mcp__weapp-agent-mcp__page_getElements",
"mcp__weapp-agent-mcp__page_waitElement",
"mcp__weapp-agent-mcp__page_waitElementGone",
"mcp__weapp-agent-mcp__page_waitRoute",
"mcp__weapp-agent-mcp__page_waitTimeout",
"mcp__weapp-agent-mcp__page_expectRoute",
"mcp__weapp-agent-mcp__page_expectVisible",
"mcp__weapp-agent-mcp__page_expectElementText",
"mcp__weapp-agent-mcp__page_expectCount",
"mcp__weapp-agent-mcp__page_expectData",
"mcp__weapp-agent-mcp__page_getData",
"mcp__weapp-agent-mcp__page_setData",
"mcp__weapp-agent-mcp__page_callMethod",
"mcp__weapp-agent-mcp__element_tap",
"mcp__weapp-agent-mcp__element_touch",
"mcp__weapp-agent-mcp__element_swipe",
"mcp__weapp-agent-mcp__element_input",
"mcp__weapp-agent-mcp__element_callMethod",
"mcp__weapp-agent-mcp__element_getData",
"mcp__weapp-agent-mcp__element_setData",
"mcp__weapp-agent-mcp__element_getInnerElement",
"mcp__weapp-agent-mcp__element_getInnerElements",
"mcp__weapp-agent-mcp__element_getWxml",
"mcp__weapp-agent-mcp__element_getStyles",
"mcp__weapp-agent-mcp__element_scrollTo",
"mcp__weapp-agent-mcp__element_getAttributes",
"mcp__weapp-agent-mcp__element_getBoundingClientRect"
]
}
}注意: 工具名称格式为
mcp__<服务器名称>__<工具名称>,请确保服务器名称与您的 MCP 配置中的名称一致。
启动微信开发者工具
在使用 MCP 服务器之前,需要先启动微信开发者工具并开启 WebSocket 服务。
💡 在开始之前:
- 打开微信开发者工具
- 进入 设置 → 安全设置 → 服务端口
- 开启 "HTTP 调试" 和 "自动化测试"
使用命令行启动
使用命令行启动微信开发者工具并自动开启 WebSocket 服务:
macOS/Linux:
/Applications/wechatwebdevtools.app/Contents/MacOS/cli auto --project /path/to/your/project --auto-port 9420Windows:
"C:\Program Files (x86)\Tencent\微信web开发者工具\cli.bat" auto --project C:\path\to\your\project --auto-port 9420其中:
--project参数指定小程序项目目录路径(请替换为实际的项目路径)--auto-port参数指定 WebSocket 服务端口(默认 9420)
⚠️ 警告 由于沙箱机制,部分客户端不允许 MCP 访问项目目录以外的微信开发者工具的 cli,所以这里只介绍了使用 WebSocket 服务
环境变量配置
通过环境变量控制自动化工具如何连接到微信开发者工具:
| 变量 | 说明 |
| --- | --- |
| WEAPP_WS_ENDPOINT | 【推荐】 已运行的开发者工具自动化 WebSocket 端点。设置后,服务器使用 connect 模式而不是启动新实例。示例:ws://localhost:9420 |
| WECHAT_DEVTOOLS_CLI_PATH | 微信开发者工具 CLI 路径(如果默认路径有效则可选)。 |
| WEAPP_AUTOMATOR_MODE | 强制使用 launch 或 connect 模式。除非提供了 WEAPP_WS_ENDPOINT,否则默认为 launch。 |
| WEAPP_DEVTOOLS_PORT | launch 模式下传给 cli auto --auto-port 的自动化端口。不会在失败后自动切到其他端口。 |
| WEAPP_DEVTOOLS_TIMEOUT | 启动超时时间(毫秒,默认 30000)。 |
| WEAPP_AUTO_ACCOUNT | 传递给 --auto-account 用于自动登录。 |
| WEAPP_DEVTOOLS_TICKET | 启动时传递给 --ticket。 |
| WEAPP_TRUST_PROJECT | 设置为 true 以在启动时包含 --trust-project。 |
| WEAPP_DEVTOOLS_ARGS | 启动时的额外 CLI 参数(空格分隔)。 |
| WEAPP_DEVTOOLS_CWD | 传递给开发者工具进程的工作目录。 |
| WEAPP_AUTOCLOSE | 设置为 true 时,每次工具调用后关闭开发者工具会话。 |
| WEAPP_AUTOLAUNCH | 仅在显式 launch 路径下用于辅助启动开发者工具;不会在 connect 失败后自动切换模式或端口 |
| WEAPP_LAUNCH_TIMEOUT | 启动超时时间(毫秒,默认 45000) |
| WEAPP_CONNECT_TIMEOUT | 连接超时时间(毫秒,默认 45000) |
| WEAPP_PROJECT_PATH | 小程序项目路径(可选) |
注意: 当启动开发者工具(
launch模式)时,必须通过 MCP 工具参数提供小程序项目目录:在执行操作前通过connection.projectPath提供(例如通过mp_ensureConnection)。该值一旦建立,将在后续调用中持久化。
工具调用可以通过 connection 对象覆盖这些默认值中的大部分。
连接模式说明
模式 A:连接已有 IDE(connect)
适用于你已经手动打开微信开发者工具,并且已经在 设置 → 安全设置 → 服务端口 中开启了自动化。
{
"mcpServers": {
"weapp-agent-mcp": {
"command": "npx",
"args": ["-y", "@chaixueyuan/weapp-agent-mcp"],
"env": {
"WEAPP_WS_ENDPOINT": "ws://localhost:9420"
}
}
}
}这个模式下:
WEAPP_WS_ENDPOINT必须指向可被miniprogram-automator.connect()连接的 websocket endpoint- 不要把 IDE HTTP 端口误当成 websocket 端口
- 不要再执行
cli open、cli auto、cli quit - 建议先调用
mp_diagnoseConnection,再调用mp_ensureConnection - 如果连接失败,只返回诊断结果,不要自动切端口
模式 B:由 MCP 拉起 IDE(launch)
适用于当前未打开 IDE,需要 MCP 通过 CLI 启动项目。
{
"mcpServers": {
"weapp-agent-mcp": {
"command": "npx",
"args": ["-y", "@chaixueyuan/weapp-agent-mcp"],
"env": {
"WEAPP_AUTOMATOR_MODE": "launch",
"WEAPP_PROJECT_PATH": "/path/to/project",
"WECHAT_DEVTOOLS_CLI_PATH": "/Applications/wechatwebdevtools.app/Contents/MacOS/cli",
"WEAPP_DEVTOOLS_PORT": "9420"
}
}
}
}这个模式下:
WEAPP_DEVTOOLS_PORT表示cli auto --auto-port使用的自动化端口- 只有在明确使用
launch模式时,MCP 才应该启动 IDE - 如果检测到同项目已经有 IDE 实例在运行,应停止自动 launch 并返回诊断信息
connect与launch两种模式不要混用
--port 和 --auto-port 的区别
微信开发者工具至少涉及两类端口:
--port:IDE HTTP 服务端口--auto-port:自动化 websocket 端口
这两个端口不能混用。WEAPP_WS_ENDPOINT 必须指向自动化 websocket 端口,而不是 IDE HTTP 端口。
Codex / agent 使用规则
当用户已经打开微信开发者工具时:
- 不要执行
cli open - 不要执行
cli auto - 不要执行
cli quit - 先调用
mp_diagnoseConnection - 再调用
mp_ensureConnection - 如果连接失败,只返回诊断结果,不要自动切端口
可用工具
应用工具(Application Tools)
mp_diagnoseConnection– 只诊断当前连接目标,不启动 IDE、不修改项目状态mp_ensureConnection– 确保自动化会话就绪;建议先调用mp_diagnoseConnection,再决定是否重连或覆盖连接设置mp_navigate– 在小程序内导航,支持navigateTo、redirectTo、reLaunch、switchTab或navigateBackmp_screenshot– 捕获屏幕截图并返回(或保存到磁盘)mp_callWx– 调用微信小程序 API 方法(如wx.showToast)mp_evaluate– 向小程序 AppService 注入并执行函数代码,适合做显式运行时读取mp_getLogs– 获取小程序控制台日志,支持按type、contains、since、limit过滤,并返回日志监听状态(如listenerAttached、lastLogAt、sessionId)mp_runScenario– 按顺序执行一组最小测试步骤,当前支持navigate、tap、input、waitRoute、expect*、snapshot、getLogs、screenshotmp_generateScenarioReport– 执行 scenario 并输出 markdown 报告;可选写入outputPath,适合产出轻量回归测试记录,并可引用截图路径mp_currentPage– 获取当前页面信息(路径、查询参数、尺寸和滚动位置),withData为 true 时额外返回页面数据mp_healthCheck– 聚合连接、页面、项目路径和日志监听状态,判断当前是否健康、是否需要恢复mp_recoverConnection– 按标准顺序执行恢复,并返回恢复动作、恢复前后状态与最新 healthmp_listProjects– 列出微信开发者工具中的最近项目,方便选择项目目录mp_setDefaultProject– 设置默认的小程序项目路径,设置后下次连接会自动使用该项目
页面工具(Page Tools)
page_getElement– 通过选择器获取页面元素,返回元素摘要信息(tagName、text、value、size、offset);设置withWxml: true可额外返回完整 outerWxml;支持 [index=N] 语法选择第 N 个元素page_getElements– 通过选择器获取页面元素数组,返回每个元素的摘要信息;设置withWxml: true可额外返回每个元素的完整 outerWxml;支持 [index=N] 语法page_waitElement– 等待元素出现在页面上(⚠️ 不适用于自定义组件内部元素);支持 [index=N] 语法;增加超时和重试间隔参数page_waitElementGone– 等待元素从页面上消失;支持 [index=N] 语法;支持超时和重试间隔参数page_waitRoute– 等待当前页面路径变为指定值,适合确认导航真正完成;支持超时和重试间隔参数page_waitTimeout– 等待指定的毫秒数page_expectRoute– 断言当前页面路径是否等于预期值page_expectVisible– 断言页面上是否存在可定位到的元素;支持[index=N]语法page_expectElementText– 断言元素文本是否等于或包含预期值;支持[index=N]语法page_expectCount– 断言页面上匹配选择器的元素数量是否等于预期值page_expectData– 断言当前页面指定data路径的值是否与预期相等page_snapshot– 返回当前页面的轻量结构快照,聚合 route、query、指定 data 路径和值,以及关键选择器的元素摘要;不默认处理页面 title,标题校验请用明确选择器配合page_expectElementTextpage_getData– 获取当前页面的数据对象,可选择指定子数据路径page_setData– 使用setData更新当前页面的数据page_callMethod– 调用当前页面实例上暴露的方法
元素工具(Element Tools)
element_tap– 通过 CSS 选择器模拟点击 WXML 元素;支持 [index=N] 语法选择第 N 个元素element_touch– 对元素执行真实触摸事件;支持start/move/end/sequence四种模式,坐标基于元素左上角,默认取元素中心;支持 [index=N] 语法element_swipe– 对元素执行真实滑动手势;支持up/down/left/right,可指定距离和持续时间;支持 [index=N] 语法element_input– 向元素输入文本(适用于input和textarea组件)element_callMethod– 调用自定义组件实例的方法element_getData– 获取自定义组件实例的渲染数据element_setData– 设置自定义组件实例的渲染数据element_getInnerElement– 获取元素内的元素(相当于element.$(selector)),返回元素摘要信息;设置withWxml: true可额外返回完整 outerWxmlelement_getInnerElements– 获取元素内的元素数组(相当于element.$$(selector)),返回元素摘要信息;设置withWxml: true可额外返回每个元素的完整 outerWxmlelement_getWxml– 获取元素 WXML(内部或外部)element_getStyles– 获取元素的 CSS 样式值,names 参数为样式名数组(如['color', 'fontSize'])element_scrollTo– 滚动 scroll-view 组件到指定位置(x, y)element_getAttributes– 获取元素的特性值,names 参数为特性名数组(如['class', 'id', 'data-index'])element_getBoundingClientRect– 获取元素相对于视口的边界矩形信息(left、top、width、height、right、bottom),考虑 CSS transform 变换(目前仅支持 ID 选择器、类选择器)
每个工具都接受可选的 connection 块来覆盖环境默认值(项目路径、CLI 路径、WebSocket 端点等)。
使用技巧
一般提示
- 连接前,在微信开发者工具中启用自动化(
设置 → 安全设置 → 服务端口) - 推荐先调用
mp_diagnoseConnection,再调用mp_ensureConnection来验证连接并查看系统/页面详情 - 使用
WEAPP_AUTOCLOSE=true适合无状态的一次性交互 - 导航时始终使用绝对路径(以
/开头):/pages/mine/mine - tabBar 页面使用
switchTab,普通页面使用navigateTo switchTab只应视为一种导航动作,不应默认作为底部 tab UI 选中态的判断依据;很多项目会自定义底部 tab
操作自定义组件
操作自定义组件时,有两种方法:
方法一:使用 innerSelector 参数(推荐)
适用于 element_tap、element_input、element_getWxml 等工具:
{
"selector": "#my-component",
"innerSelector": ".inner-button"
}selector:自定义组件的选择器innerSelector:组件内部元素的选择器
方法二:使用元素内查询工具
适用于 element_getInnerElement 和 element_getInnerElements:
{
"selector": "#my-component",
"targetSelector": ".inner-button"
}限制说明
page_waitElement不适用于自定义组件内部元素。请使用page_waitTimeout配合元素查询工具进行轮询检查。- 页面跳转校验可优先使用
page_waitRoute,比单纯mp_navigate后固定等待更稳。 - 临时弹层、loading、toast 等消失场景可使用
page_waitElementGone。
自动启动功能(AutoLaunch)
WEAPP_AUTOLAUNCH=true 现在只应理解为 显式 launch 配置下的启动辅助开关,不是 connect 失败后的兜底恢复策略。
当前安全策略是:
- 如果用户已经手动打开 IDE,应优先使用
connect connect失败时先诊断,不自动切模式、不自动切端口- 只有明确进入
launch模式时,MCP 才尝试启动 IDE - 如果检测到 DevTools 已在运行,会优先阻止重复拉起
配置示例
{
"mcpServers": {
"weapp-agent-mcp": {
"command": "npx",
"args": [
"-y",
"@chaixueyuan/weapp-agent-mcp"
],
"env": {
"WEAPP_AUTOLAUNCH": "true",
"WEAPP_PROJECT_PATH": "D:\\path\\to\\your\\project"
}
}
}
}工作流程
- 首次连接时,检测到
WEAPP_AUTOLAUNCH=true - 检查 9420 端口是否有服务
- 无服务则自动启动开发者工具(使用
cli.bat auto --project <path> --auto-port 9420) - 等待 45 秒让开发者工具就绪
- 建立 WebSocket 连接
- 后续连接自动复用现有连接
提示:使用
mp_setDefaultProject设置默认项目后,下次连接无需再次选择项目。
