Minium 是微信测试团队为小程序专门开发的自动化框架。它实现了miniprogram-automator 中小程序自动化能力。使用 Minium 可以进行小程序 UI 自动化测试,但是 minium 的功能不止于仅仅是 UI 自动化,甚至可以使用 Minium 来进行函数的 Mock,可以直接跳转到小程序某个页面并设置页面数据,做针对性的全面测试,这些都得益于我们开放了部分小程序 API 的能力。此外,还支持并封装了所有的原生操作都进行了封装,屏蔽了 iOS/Android 底层差异,实现了一套脚本在三端同时运行

下面重点介绍 Minium 的安装和使用,以及可能遇到的问题和解决方案

安装 Minium 框架

pip 安装,拉取最新版本 minium

`pip3 install https://minitest.weixin.qq.com/minium/Python/dist/minium-latest.zip

下载 minium 安装包,解压后进入文件夹,python 安装

python3 setup.py install

环境检查

minitest -v

例如输出以下信息

{'version': '1.2.8', 'revision': 'd9e296d820fc572ce7a36bef23f16294e8dbaf46', 'branch': 'master', 'update_at': '2022-07-01 14:30:51'}

`"path/to/cli" auto --project "path/to/project" --auto-port 9420

可能遇到的问题

Error: Port 9420 is in use (code 10)

关闭项目,杀掉端口进程,重新执行,或者使用其他端口号

receive from remote timeout, id:xxxxxxxxxxx

一般是因为 ide 的通道被远程调试占用了,请检查 ide 是否有打开。建议关闭工具,重新执行,防止端口被占用。或者网络环境等原因引起

确认下开发者工具上选用的基础库是最新的:开发者工具项目窗口右上角 -> 详情 -> 本地设置 -> 调试基础库

注意

PyCharm + 虚拟环境 配置开发环境

PyCharm 工具编写用例脚本,使用 Minium 框架,配置虚拟环境,具体操作如下

简单例子

小程序 demo 参考 miniprogram-demo

简单 UI 页面操作
class FirstTest(minium.MiniTest):
        def test_ui_op(self):
            # 页面跳转
            self.app.switch_tab("/pages/index/index")
            # 元素定位
            ele = self.page.get_element("/page/view/navigator[3]/button")
            # 元素点击
            ele.click()
            # 判断元素是否存在
            self.assertTrue(self.page.element_is_exists("/page/view[9]/mytest//view", max_timeout=5))
            # 打印元素文本
            inner = self.page.get_element("/page/view[9]/mytest//view").inner_text
            self.logger.info("UI Case %s", inner)
config.json 配置
{
  "project_path":"xxx",     // 小程序项目路径
  "dev_tool_path":"xxx",  // 微信开发者工具安装路径
  "platform": "ide"
}
运行 case

minitest -m test.first_test -c config.json -g

运行结果

查看结果

测试结果默认存储在 outputs 文件下,运行命令 python3 -m http.server 12345 -d outputs 然后在浏览器上访问 http://localhost:12345 即可查看报告,如图:

需要帮助

如果在微信小程序自动化测试过程中遇到任何问题,欢迎在 微信小程序云测服务 专区发帖反馈

也可以微信扫描二维码加入云测官方企业微信群,联系 MiniTest 小助手反馈


↙↙↙阅读原文可查看相关链接,并与作者交流