一、minium简介
minium 是为小程序专门开发的自动化框架。使用 minium 可以进行小程序 UI 自动化测试, 但是 minium 的功能不止于仅仅是 UI 自动化, 甚至可以使用 minium 来进行函数的 mock, 可以直接跳转到小程序某个页面并设置页面数据, 做针对性的全面测试, 这些都得益于我们开放了部分小程序 API 的能力。除此之外,小程序有部分组件使用了系统原生的组件,对于这部分的组件,我们也基于 uiautomator 和 wda 做了补充。
目前小程序的体量越来越大,相关的框架和组件库越来越多,对于测试能力要求也越来越高。业内同行基于Chrome DevTools Protocol开发了很多小程序相关的测试工具,这些工具都有以下缺点:
- 只能在Android端上运行。小程序实际是一个跨平台的产品(IDE,Android和IOS),测试的平台覆盖不足。
- 兼容性问题。小程序底层运行的内核多样化(x5,原生webview内核等等),对应的调试端口不一定能够打开。
- 只能做UI相关的测试。小程序架构上分为渲染层和逻辑层,这些框架对于逻辑层上面的测试限制较大。
而 minium 除了以上缺点都没有之外,还支持以下更多特性:
- 支持一套脚本,iOS & Android & 模拟器,三端运行
- 提供丰富的页面跳转方式,看不到也能去得到
- 可以获取和设置小程序页面数据,让测试不止点点点
- 可以直接触发小程序元素绑定事件
- 支持往 AppSerive 注入代码片段执行
- 可以调用部分 wx 对象上的接口
- 支持 Mock wx 对象上的接口
- 支持 Hook wx 对象上的接口
- 通过 suite 方式管理用例,config 管理运行设备
暂不支持
H5页面的调试
真机调试2.0
二、minium 环境搭建
- 安装python环境:Python 3.8及以上
- 安装官方文档或直接访问官方文档
安装步骤:
(1)下载文档源码(需要先设置用户名和密码):官方地址
(2)安装 docsifygit clone https://git.weixin.qq.com/minitest/minium-doc.git
(3)进入目录中使用npm进行构建npm i docsify-cli -g
(4)本地部署cd minium-doc npm install
(5)通过http://localhost:3000进行访问docsify serve .
- 安装最新的minium库,可以先下载后在使用pip进行安装
pip install https://minitest.weixin.qq.com/minium/Python/dist/minium-latest.zip # 安装完成后使用以下命令进行检查 minitest -v
- 安装微信开发者工具
需要在开发者工具-设置-安全设置中开放端口
- 检查是否能够自动打开微信开发这工具
# "path/to/cli" 微信开发这工具目录 # "path/to/project" 小程序项目目录 # 若配置成功 输出结果前面都会带√ "path/to/cli" auto --project "path/to/project" --auto-port 9420
- 设置开发这工具调试基础库
如果基础库版本过低,会出现错误
开发者工具点击右上角详情-本地设置-调试基础库
三、简单实例
-
在小程序中创建一个Hello World实例
-
pycharm创建一个项目 目录结构如下
. ├── minitest │ └── __init__.py │ └── testcase │ └── __init__.py │ └── test01.py │ └── config.json
-
实例代码
import minium class FirstTest(minium.MiniTest): def test01(self): # 获取元素 并进行断言 self.assertEqual(self.page.get_element(".user-motto").inner_text, "Hello World","判断文本是否正确")
-
配置文件,配置信息详情可参考:官方文档
{ "platform": "ide", "project_path": "/Users/chnjx/WeChatProjects/miniprogram-1", "dev_tool_path": "/Applications/wechatwebdevtools.app/Contents/MacOS/cli" }
-
执行命令运行用例
# -c 后面接json配置文件 -m 接测试用例包名 -g表示生成测试报告 minitest -c config.json -m testcase.test01 -g
-
查看测试报告,output目录下的index.html使用浏览器进行打开