微信小程序的自动化测试框架
微信发布了小程序的自动化测试框架Minium,提供了多种运行验证方式,其特点:
支持一套脚本,iOS & Android & 模拟器,三端运行
提供丰富的页面跳转方式,看不到也能去得到
可以获取和设置小程序页面数据,让测试不止点点点
可以直接触发小程序元素绑定事件
支持往 AppSerive 注入代码片段
可以调用部分 wx 对象上的接口
minium 是为小程序专门开发的自动化框架, 提供了 Python 和 JavaScript 版本。使用 minium 可以进行小程序 UI 自动化测试, 但是 minium 的功能不止于仅仅是 UI 自动化, 甚至可以使用 minium 来进行函数的 mock, 可以直接跳转到小程序某个页面并设置页面数据, 做针对性的全面测试, 这些都得益于我们开放了部分小程序 API 的能力。除此之外,小程序有部分组件使用了系统原生的组件,对于这部分的组件,我们也基于 uiautomator 和 wda 做了补充。
环境依赖
文档使用
Minium的文档是采用Nodejs编写的,因此想看文档还需要安装NodeJs的环境,如果你不知道怎么安装请自行查找。文档的安装:
npm i docsify-cli -g
然后checkout文档项目:
git clone https://git.weixin.qq.com/minitest/minium-doc
安装依赖:
cd minium-doc
npm install
本地部署:
docsify serve .
框架依赖运行环境部署
接下来,你要打开微信开发者工具的安全模式
然后安装Minium:
pip3 install minium-0.0.2.zip
使用
首先你要通过命令行启动开发者工具提供了命令行
命令行
通过命令行调用安装完成的工具可执行文件,完成登录、预览、上传、自动化测试等操作。调用返回码为 0 时代表正常,为 -1 时错误。
命令行工具所在位置:
macOS: /Contents/MacOS/cli
Windows: /cli.bat
命令行启动工具
-o, --open [projectpath]: 打开工具,如果不带 projectpath,只是打开工具。如果带 project path,则打开路径中的项目,每次执行都会自动编译刷新,并且自动打开模拟器和调试器。projectpath 不能是相对路径。项目路径中必须含正确格式的 project.config.json 且其中有 appid 和 projectname 字段。
示例:
打开工具
cli -o
打开路径 /Users/username/demo 下的项目
cli -o /Users/username/demo
输入如下命令:
path/to/cli --auto /miniprogram/project/path --auto-port 9420
# path/to/cli 是命令行工具所在位置:
# macOS: /Contents/MacOS/cli
# Windows: /cli.bat windows版本在安装之后默认会把cli加入到系统路径,可以先测试cli命令是否可用,如果可用,path/to/cli可以直接用cli替换
# /miniprogram/project/path 是小程序工程的路径( Windows下面用 \\ 代替 \ )
特别说明:
1、这里的--auto-port请填写 9420,不是开发者工具安全模式的端口
2、请确保开发者工具登陆的微信号具备被测小程序的开发者权限
3、如果没有Open project with automation enabled success的输出,否则请检查IDE版本(开发者工具调试基础库版本 >= 2.7.3),或者检查命令行参数
关注我,关注测试