weapp-agent-mcp

mcp
Security Audit
Fail
Health Warn
  • License — License: MIT
  • Description — Repository has a description
  • Active repo — Last push 0 days ago
  • Low visibility — Only 5 GitHub stars
Code Fail
  • process.env — Environment variable access in src/config.ts
  • new Function() — Dynamic code execution via Function constructor in src/tools/common.ts
  • exec() — Shell command execution in src/tools/element.ts
Permissions Pass
  • Permissions — No dangerous permissions requested

No AI report is available for this listing yet.

SUMMARY

Agent-first MCP server for WeChat Mini Program debugging & automation. 面向 agent 的微信小程序 MCP 服务,让 Claude Code / Cursor 直接操作微信开发者工具。

README.md

weapp-agent-mcp

npm version
npm downloads
license
MCP

Agent-first MCP server for WeChat Mini Program debugging, automation, and lightweight regression testing.

面向 agent 的微信小程序 MCP 服务 — 让 Claude Code / Cursor / Codex 等 agent 在对话中直接驱动微信开发者工具完成调试、UI 操作、页面巡检与轻量测试。

📖 Changelog · 🐛 Issues · 💬 Discussions

weapp-agent-mcp 是一个面向 agent 的微信小程序 MCP 服务,基于 miniprogram-automator 封装微信开发者工具自动化能力,用于页面调试、元素操作、轻量回归测试与恢复友好型排查。

它适合:

  • agent 主开发 / 主调试
  • 串行截图与页面巡检
  • 轻量 scenario / report
  • 基于稳定 selector 的自动化验证

它当前不应被宣传为:

  • 并发截图通道
  • 超长高压全链路回归引擎

文档导航

更完整的文档入口见 docs/README.md

为什么选 weapp-agent-mcp

如果你已经在用 Claude Code / Cursor / Codex 等 agent 写小程序,传统的 miniprogram-automator 脚本式调用不够顺手 — 你得让 agent 写 node 脚本、跑、读输出、再调整。本项目把自动化能力直接暴露成 agent 工具调用,让 agent 在对话中可以:

  • 🤖 零脚本调试 — 直接调用 mp_screenshot / page_snapshot / element_tap,不必中转脚本
  • 🔁 恢复友好 — 内置 mp_healthCheck / mp_recoverConnection,断连后能自愈,长会话更稳
  • 📋 轻量回归mp_runScenario + mp_generateScenarioReport 产出 markdown 报告,适合给 PR / oncall 用
  • 🎯 稳定 selector 优先 — 设计上鼓励 qa-* 命名锚点,减少 UI 改版后的脚本碎裂

适用 / 不适用对比

场景 是否适用
Agent 主动驱动调试 / 巡检 ✅ 主推场景
写传统脚本式 e2e 测试 ⚪ 直接用原生 miniprogram-automator SDK 更轻
并发截图 / 压测 ❌ 不适用 — 截图通道按串行设计
长会话 / 多轮调试 ✅ 有 health / recover 工具兜底
CI 上的长链路回归 ⚠️ 拆短 scenario 后可用,超长链路建议专业框架

前置要求

  • 已安装微信开发者工具,支持命令行访问(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_snapshotmp_screenshot、长 mp_runScenario 在连续复杂操作后可能超时
  • 若出现连续失败,先运行 mp_healthCheck;仅当 needsRecovery=true 时执行 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_pollUntil",
      "mcp__weapp-agent-mcp__mp_getLogs",
      "mcp__weapp-agent-mcp__mp_runScenario",
      "mcp__weapp-agent-mcp__mp_generateScenarioReport",
      "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_snapshot",
      "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 配置中的名称一致。

可选:人工预启动微信开发者工具

默认流程无需 agent 手动执行 CLI:直接调用 mp_ensureConnection,本地端口未监听且允许 AutoLaunch 时,server 会自行执行 cli auto。下面的命令只用于人工排障,或显式设置 WEAPP_AUTOLAUNCH=false 后由用户自行预启动开发者工具。

💡 在开始之前:

  1. 打开微信开发者工具
  2. 进入 设置 → 安全设置 → 服务端口
  3. 开启 "HTTP 调试""自动化测试"

人工使用命令行启动

使用命令行启动微信开发者工具并自动开启 WebSocket 服务:

macOS:

/Applications/wechatwebdevtools.app/Contents/MacOS/cli auto --project /path/to/your/project --auto-port 9420

Windows:

"C:\Program Files (x86)\Tencent\微信web开发者工具\cli.bat" auto --project C:\path\to\your\project --auto-port 9420

其中:

  • --project 指定小程序项目目录路径(请替换为实际的项目路径)
  • --auto-port 指定 automation websocket 端口(默认 9420)。注意:这个 flag 在 cli auto --help 输出里看不到,但官方 miniprogram-automator SDK 内部一直用,是有效参数

⚠️ 警告
由于沙箱机制,部分客户端不允许 MCP 访问项目目录以外的微信开发者工具的 cli,所以这里只介绍了使用 WebSocket 服务

环境变量配置

通过环境变量控制自动化工具如何连接到微信开发者工具:

变量 说明
WEAPP_WS_ENDPOINT 【推荐】 已运行的开发者工具自动化 WebSocket 端点。设置后,服务器使用 connect 模式而不是启动新实例。示例:ws://localhost:9420
WECHAT_DEVTOOLS_CLI_PATH 微信开发者工具 CLI 路径(如果默认路径有效则可选)。
WEAPP_AUTOMATOR_MODE 强制使用 launchconnect 模式。除非提供了 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 本地 connect 目标端口未监听时是否允许 mp_ensureConnection 使用 cli auto 拉起开发者工具;默认允许,设为 false 禁用。不会自动切换端口或拉起远程目标。
WEAPP_LAUNCH_TIMEOUT 启动超时时间(毫秒,默认 45000)
WEAPP_CONNECT_TIMEOUT 连接超时时间(毫秒,默认 45000)
WEAPP_PROJECT_PATH 小程序项目路径(可选)

注意: launch / 本地自动拉起最终都需要可解析的小程序项目目录。可通过 connection.projectPathWEAPP_PROJECT_PATHmp_setDefaultProject 的持久化默认值、最近项目或当前工作目录提供;显式设置的默认项目不会被后续活动会话覆盖。

工具调用可以通过 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 opencli autocli quit
  • 默认直接调用 mp_ensureConnection;它会优先复用现有会话,并在本地端口未监听时按配置自愈
  • 只想只读探测,或 ensure / recovery 已失败时,再调用 mp_diagnoseConnection
  • 不要自动切端口;如需禁止 ensure 自动执行 cli auto,设置 WEAPP_AUTOLAUNCH=false

模式 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 并返回诊断信息
  • connectlaunch 两种模式不要混用

--port--auto-port 的区别

微信开发者工具至少涉及两类端口:

  • --port:IDE HTTP 服务端口
  • --auto-port:自动化 websocket 端口

这两个端口不能混用。WEAPP_WS_ENDPOINT 必须指向自动化 websocket 端口,而不是 IDE HTTP 端口。

Codex / agent 使用规则

当用户已经打开微信开发者工具时:

  1. 不要执行 cli open
  2. 不要执行 cli quit
  3. 默认直接调用 mp_ensureConnection,它会优先复用现有自动化会话
  4. mp_diagnoseConnection 仅用于只读探测,或在 ensure / recovery 失败后补充诊断
  5. 不要手动切端口;本地自动化端口未监听且 WEAPP_AUTOLAUNCH 未禁用时,mp_ensureConnection 可自行执行 cli auto
  6. 不允许自动拉起时设置 WEAPP_AUTOLAUNCH=false

可用工具

应用工具(Application Tools)

  • mp_diagnoseConnection – 只诊断当前连接目标,不启动 IDE、不修改项目状态
  • mp_ensureConnection – 确保自动化会话就绪,是连接链路默认入口;失败后再按返回指引诊断或恢复
  • mp_navigate – 在小程序内导航,支持 navigateToredirectToreLaunchswitchTabnavigateBack
  • mp_screenshot – 捕获屏幕截图并返回(或保存到磁盘)
  • mp_callWx – 调用微信小程序 API 方法(如 wx.showToast
  • mp_evaluate – 向小程序 AppService 注入并执行函数代码,适合做显式运行时读取
  • mp_pollUntil – 轮询 AppService 条件,命中后可执行动作并采集前后状态快照
  • mp_getLogs – 获取小程序控制台日志,支持按 typecontainssincelimit 过滤,并返回日志监听状态(如 listenerAttachedlastLogAtsessionId
  • mp_runScenario – 按顺序执行一组最小测试步骤,当前支持 navigatetapinputwaitRouteexpect*snapshotgetLogsscreenshot
  • mp_generateScenarioReport – 执行 scenario 并输出 markdown 报告;可选写入 outputPath,适合产出轻量回归测试记录,并可引用截图路径
  • mp_currentPage – 获取当前页面信息(路径、查询参数、尺寸和滚动位置),withData 为 true 时额外返回页面数据
  • mp_healthCheck – 聚合连接、页面、项目路径和日志监听状态,判断当前是否健康、是否需要恢复
  • mp_recoverConnection – 按标准顺序执行恢复,并返回恢复动作、恢复前后状态与最新 health
  • mp_listProjects – 列出微信开发者工具中的最近项目,方便选择项目目录
  • mp_setDefaultProject – 设置默认的小程序项目路径,设置后下次连接会自动使用该项目

页面工具(Page Tools)

  • page_getElement – 通过选择器获取页面元素,返回元素摘要信息(tagName、text、value、size、offset);设置 withWxml: true 可额外返回完整 outerWxml;支持 [index=N] 语法选择第 N 个元素
  • page_getElements – 通过选择器获取页面元素数组,返回每个元素的摘要信息;limit 默认/最大 100;设置 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_expectElementText
  • page_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 – 向元素输入文本(适用于 inputtextarea 组件)
  • element_callMethod – 调用自定义组件实例的方法
  • element_getData – 获取自定义组件实例的渲染数据
  • element_setData – 设置自定义组件实例的渲染数据
  • element_getInnerElement – 获取元素内的元素(相当于 element.$(selector)),返回元素摘要信息;设置 withWxml: true 可额外返回完整 outerWxml
  • element_getInnerElements – 获取元素内的元素数组(相当于 element.$$(selector)),返回元素摘要信息;limit 默认/最大 100;设置 withWxml: true 可额外返回每个元素的完整 outerWxml
  • element_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_ensureConnection 建立或复用会话;只读探测或连接失败排查再用 mp_diagnoseConnection
  • 使用 WEAPP_AUTOCLOSE=true 适合无状态的一次性交互
  • 导航时始终使用绝对路径(以 / 开头):/pages/mine/mine
  • tabBar 页面使用 switchTab,普通页面使用 navigateTo
  • switchTab 只应视为一种导航动作,不应默认作为底部 tab UI 选中态的判断依据;很多项目会自定义底部 tab

操作自定义组件

操作自定义组件时,有两种方法:

方法一:使用 innerSelector 参数(推荐)

适用于 element_tapelement_inputelement_getWxml 等工具:

{
  "selector": "#my-component",
  "innerSelector": ".inner-button"
}
  • selector:自定义组件的选择器
  • innerSelector:组件内部元素的选择器

方法二:使用元素内查询工具

适用于 element_getInnerElementelement_getInnerElements

{
  "selector": "#my-component",
  "targetSelector": ".inner-button"
}

限制说明

  • page_waitElement 不适用于自定义组件内部元素。请使用 page_waitTimeout 配合元素查询工具进行轮询检查。
  • 页面跳转校验可优先使用 page_waitRoute,比单纯 mp_navigate 后固定等待更稳。
  • 临时弹层、loading、toast 等消失场景可使用 page_waitElementGone

自动启动功能(AutoLaunch)

本地 connect 目标端口未监听时,mp_ensureConnection 默认会使用 cli auto 拉起开发者工具。设置 WEAPP_AUTOLAUNCH=false 可显式禁用。远程 wsEndpoint 不会触发本机自动拉起。

当前安全策略是:

  1. 如果用户已经手动打开 IDE,应优先使用 connect
  2. 本地 connect 端口未监听时,MCP 可自动执行 cli auto,但不自动切模式、不自动切端口
  3. autoLaunch=false 或远程 wsEndpoint 时不会自动启动 IDE
  4. 如果检测到 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"
      }
    }
  }
}

工作流程

  1. 首次连接时,检测到本地自动化端口未监听且未设置 WEAPP_AUTOLAUNCH=false
  2. 检查 9420 端口是否有服务
  3. 无服务则自动启动开发者工具(使用 cli.bat auto --project <path> --auto-port 9420
  4. WEAPP_LAUNCH_TIMEOUT 等待开发者工具就绪(默认 45 秒)
  5. 建立 WebSocket 连接
  6. 后续连接自动复用现有连接

提示:使用 mp_setDefaultProject 设置默认项目后,下次连接无需再次选择项目。

Reviews (0)

No results found