AWTK 回归测试。
有些需要界面交互的测试,无法放到单元测试里,就放到回归测试里。
一般来说修改代码时,要么通过单元测试验证,要么通过回归测试验证,可以有效避免新加功能或修复BUG时引入新的问题。
- 安装Appium
请参考
- 获取 awtk 并编译
git clone https://github.com/zlgopen/awtk.git
cd awtk; scons; cd -
- 获取 awtk-restful-httpd 并编译
git clone https://github.com/zlgopen/awtk-restful-httpd.git
cd awtk-restful-httpd; scons; cd -
- 获取 awtk-ui-automation 并编译
git clone https://github.com/zlgopen/awtk-ui-automation.git
cd awtk-ui-automation; scons
- 获取 awtk-regression-test 并编译
git clone https://github.com/zlgopen/awtk-regression-test.git
cd awtk-regression-test
- 生成资源
python ./scripts/update_res.py all
或者通过 designer 生成资源
- 编译PC版本
scons
- 编译LINUX FB版本
scons LINUX_FB=true
完整编译选项请参考编译选项
先运行 Appium,点击“Start Server”启动服务。
运行自动测试
cd uitests
#第一次运行时,先安装依赖的软件包,如果通过离线配置了回归测试的话,就不需要执行这个命令。
npm install
#运行测试,该处会自动运行bin/demo程序
npm run test
如果无法联网的话,可参考离线配置回归测试来配置环境。
本文以 Linux/MacOS 为例,Windows 可能会微妙差异,请酌情处理。
备注:
- **回归测试程序:**是指在 uitests 文件中的 test 程序调用 indexjs 文件(是一个 js 脚本来的),需要用户在该脚本上面编写程序用例。
- **需要测试程序:**就是一开始在 awtk-regression-test 项目中编译的被测试程序,后续需要添加各种需要测试的界面和逻辑。
- **Appium:**是一个第三方的自动化测试工具,是通过 http 协议和需要测试程序通讯,实现自动化测试。