网上查了很多资料,都说 UI 自动化不好做,并且很难维护
最主要是无法理解 UI 自动化的优势,自身感觉维护起来也很困难,对于移动变化多端的移动测试起不了什么作用
同时对 UI 自动化非常的迷茫,是否有做下去或研究下去的必要
希望在这里能得到一些建议,同时也了解一下大家的 UI 自动化是怎么做的
最近也是在尝试用 appium 来实现公司 app 某些比较稳定的功能和页面的自动化测试
项目地址:https://github.com/liyuanhong/miaopaiTest
项目截图如下:
其中主要的目录和文件为:
/MPTestCases ----------- 存放测试用例
/errorScreenShot ------------ 用例执行失败生成的错误截图
startTest.py ----------- 配置了要执行的测试用例
start.cmd ----------- 用于双击启动测试(windows 下)
startTest.py 代码如下:
python
import unittest
import sys
import os
curDir = sys.path[0]
#windows下的写法
sys.path.append(curDir + '\\MPTestCases\\login')
sys.path.append(curDir + '\\MPTestCases\\shoot')
sys.path.append(curDir + '\\MPTestCases\\settingPage')
sys.path.append(curDir + '\\MPTestCases\\hotPage')
sys.path.append(curDir + '\\MPTestCases\\myPage')
sys.path.append(curDir + '\\MPTestCases\\detailPage')
#mac下的写法
sys.path.append(curDir + '/MPTestCases/login')
sys.path.append(curDir + '/MPTestCases/shoot')
sys.path.append(curDir + '/MPTestCases/settingPage')
sys.path.append(curDir + '/MPTestCases/hotPage')
sys.path.append(curDir + '/MPTestCases/myPage')
sys.path.append(curDir + '/MPTestCases/detailPage')
import MPlogin
import MPshoot
import MPsetting
import MPHotpage
import MPHotpageBanner
import MPmypage
import MPdetailPage
import MPmypageSetUserInfo
#MPlogin.suite("0")
#MPshoot.suite("0")
#MPsetting.suite("0")
#MPHotpage.suite("0")
#MPHotpageBanner.suite("0")
#MPmypage.suite("0")
#MPdetailPage.suite("0")
MPmypageSetUserInfo.suite("0")
我把测试用例都放在了 MPTestCases 目录下,一个大功能的测试用例都新建一个目录来存放测试用例
MPTestCases 目录下有一个 common 目录,用来存放测试用例中会用到的公共模块,例如初始化用例,或开屏广告,登录、退出登录等模块;用例里面需要用到的时候就直接调用;并且如果该功能有改动,只需要改一个地方就好了。
执行用例会生成一些错误截图,能够抓取到崩溃的截图;原理是每一个用例都用 try ... except ... 包起来;一旦发生异常用例就会被判断执行失败;然后就在改执行失败的界面截图一张截图,截图的名字与用例的方法名相同;因此看截图就可以知道是哪个测试用例的那个方法发生了异常。如果程序崩溃了会有两种截图(1、带有 xxx 已停止运行的对话框截图 或者 2、截取到的图片为白屏或系统桌面)
同时用例执行完会生成一个 log 文件,对比错误截图和 log 文件即可定位到用例执行失败的原因
主要作用就是用来回归测试,验证 UI 或稳定的公共是否有异常
不知道大家的 UI 自动化是怎么做的,希望多多交流