微信小程序的自动化测试框架

2021-03-04 14:10:27 浏览数 (1)

微信发布了小程序的自动化测试框架Minium,提供了多种运行验证方式,其特点:

  • 支持一套脚本,iOS & Android & 模拟器,三端运行
  • 提供丰富的页面跳转方式,看不到也能去得到
  • 可以获取和设置小程序页面数据,让测试不止点点点
  • 可以直接触发小程序元素绑定事件
  • 支持往 AppSerive 注入代码片段
  • 可以调用部分 wx 对象上的接口

官方地址如下:https://git.weixin.qq.com/minitest/minium-doc/tree/masterminium 是为小程序专门开发的自动化框架, 提供了 Python 和 JavaScript 版本。使用 minium 可以进行小程序 UI 自动化测试, 但是 minium 的功能不止于仅仅是 UI 自动化, 甚至可以使用 minium 来进行函数的 mock, 可以直接跳转到小程序某个页面并设置页面数据, 做针对性的全面测试, 这些都得益于我们开放了部分小程序 API 的能力。除此之外,小程序有部分组件使用了系统原生的组件,对于这部分的组件,我们也基于 uiautomator 和 wda 做了补充。

环境依赖

  • Python 3.x
  • 微信公共库版本 >= 2.7.3
  • 下载并安装稳定版微信开发者工具,工具下载地址:https://developers.weixin.qq.com/miniprogram/dev/devtools/stable.html
  • 如果要测Android,请下载微信测试包,下载地址:http://dldir1.qq.com/weixin/android/wechat_0x2700069A_1460.apk

文档使用

Minium的文档是采用Nodejs编写的,因此想看文档还需要安装NodeJs的环境,如果你不知道怎么安装请自行查找。文档的安装:

代码语言:javascript复制
npm i docsify-cli -g

然后checkout文档项目:

代码语言:javascript复制
git clone https://git.weixin.qq.com/minitest/minium-doc

安装依赖:

代码语言:javascript复制
cd minium-doc
npm install

本地部署:

代码语言:javascript复制
docsify serve .

然后通过浏览器访问 http://localhost:3000 即可以查看了。

框架依赖运行环境部署

首先你要先下载框架压缩包:https://git.weixin.qq.com/minitest/minium-doc/raw/master/minium/Python/dist/minium-0.0.2.zip接下来,你要打开微信开发者工具的安全模式 然后安装Minium:

代码语言:javascript复制
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

输入如下命令:

代码语言:javascript复制
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),或者检查命令行参数

0 人点赞