AirtestProject是什么
AirtestProject是由网易游戏推出的UI自动化测试解决方案,主要包含3部分内容: 1.Airtest框架:跨平台的,基于图像识别的UI自动化测试框架,支持平台有Windows、Android和iOS。 2.Poco框架:基于UI控件识别的自动化测试框架,目前支持Android原生、iOS原生、Unity3D、cocos2dx、UE4和Egret等平台,也可以在其他引擎中自行接入poco-sdk来使用。 3.AirtestIDE:跨平台的UI自动化测试编辑器,内置了Airtest和Poco的相关插件功能,能够使用它快速简单地编写Airtest和Poco代码。
关于AirtestProject的具体介绍,详见:AirtestProject官方文档。
AirtestProject简单示例
所谓AirtestProject的应用实践,即使用AirtestIDE编写Airtest和Poco代码,实现对APP的自动化操作。
对于一个从未接触过AirtestProject的新人而言,要使用AirtestProject完成对指定APP的自动化操作,实现步骤如下:
第一步:到这里下载最新版的AirtestIDE,解压到指定位置,双击AirtestIDE.exe
启动编辑器。
在启动过程中会提示用户注册账户并登录,直接点击Skip
跳过即可。
第二步:连接手机到主机,并打开调试选项,此时将会在AirtestIDE的右侧“设备窗”面板中看到已经连接的设备信息,点击“connect”按钮后即可看到手机界面。
第三步:新建Airtest脚本,点击“文件->新建脚本->.air Airtest项目”,此时会弹出一个保存Airtest脚本的对话框,设置好文件名并选择指定目录,点击“保存”按钮。
第四步:开始编写Airtest自动化测试代码。实际上,借助于AirtestIDE编辑器可以直接在通过“Airtest辅助窗”面板中的按钮生成代码。 以打开“设置”APP为例,在“Airtest辅助窗”面板中点击“touch”图标,此时移动光标到右侧的“设备窗”面板中拖动鼠标选取“设置”APP图标,此时就会在脚本文件中自动生成一段代码。
第五步:运行脚本。在AirtestIDE编辑器中点击“运行->运行脚本”,此时从右侧设备窗面板中将看到“设置”APP被点击启动了。 至此,一个非常简单的Airtest脚本就完成了。在这个简单实例中仅仅只是打开了指定APP,并没有实现任何有价值的工作,但这已经足够说明如何编写Airtest代码并实现APP自动化的流程了。
AirtestProject深入实践
通过包名启动APP
启动APP除了可以通过Airtest的图标识别方式启动之外,还可以直接通过api方式指定APP包名启动,示例代码如下:
代码语言:javascript复制# -*- encoding=utf8 -*-
__author__ = "zhangsan"
from airtest.core.api import *
auto_setup(__file__)
# 通过api指定包名启动APP
start_app("com.android.settings")
关于如果获取指定APP包名,网络上有很多教程,例如:使用adb 命令获取APP包名 。
引入其他Airtest模块
在一个正式的生产项目中,便于共用相同的逻辑,通常需要将一些公共的操作封装起来,Airtest支持引入外部的模块。 假设已经有一个封装了公共操作的Airtest模块,名称叫做“common.air”,其内容如下:
代码语言:javascript复制# -*- encoding=utf8 -*-
__author__ = "zhangsan"
from airtest.core.api import *
auto_setup(__file__)
#
# 启动APP
#
def start_app():
start_app("com.android.settings")
sleep(5.0)
在另外一个Airtest模块中可以引入该公共模块:
代码语言:javascript复制# -*- encoding=utf8 -*-
__author__ = "zhangsan"
from airtest.core.api import *
# 引入外部Airtest模块
using("common.air")
# 导入外部Airtest模块中的方法
from common import start_app
# 导入外部Airtest模块中的方法之后可以直接调用
start_app()
使用Poco定位元素
在之前的简单示例中是通过图片识别的方式实现元素定位的,其实还可以直接使用Poco框架使用表达式直接对APP中的元素定位。 需要注意的是:如果需要使用Poco框架定位元素,需要在脚本中加入对应的初始化代码。
代码语言:javascript复制# -*- encoding=utf8 -*-
__author__ = "zhangsan"
# 初始化Poco框架的代码
# 这段代码还可以在AirtestIDE编辑器左侧Poco辅助窗面板中选择对应设备类型自动生成
# 如下代码是选择Android设备自动生成的的代码
from poco.drivers.android.uiautomation import AndroidUiautomationPoco
poco = AndroidUiautomationPoco(use_airtest_input=True, screenshot_each_action=False)
相比起使用Airtest定位元素,使用Poco框架定位元素比较精准,但是在查找元素的定位标识时相对麻烦和困难(可以通过Poco辅助窗中的“Poco Inspector”实现元素查找和定位)。 如下示例展示通过Poco框架定位并打开“设置”APP。
代码语言:javascript复制poco("android.widget.FrameLayout").offspring("设置,0条通知").click()
在实际项目中有如下经验:当使用Poco框架定位困难时,可以直接使用Airtest框架的图片识别方式进行定位。 总之,使用最方便的元素定位方式即可。
关于Airtest框架和Poco框架的详见:Airtest介绍,Poco介绍 。
查看测试报告
AirtestProject项目是一个自动化测试解决方案,自然是需要有测试结果的报告说明的。在AirtestIDE编辑器中点击“运行->打开报告目录”即可在浏览器中查看对应的测试报告详情。
运行测试脚本
通常在开发环节时,直接在AirtestIDE编辑器中运行Airtest自动化测试脚本是非常方便和直接的。但是当开发完毕之后,是需要脱离IDE环境运行的。 有2种办法: 第一,根据AirtestIDE的运行脚本命令跑,如:
代码语言:javascript复制"D:ProgramFilesAirtestIDE-win-1.2.14AirtestIDEAirtestIDE" runner "D:pythonhelloworld.air" --device android://127.0.0.1:5037/14a0332c?cap_method=MINICAP&&ori_method=MINICAPORI&&touch_method=MAXTOUCH --log "C:UserszhangsanAppDataLocalTempAirtestIDEscripts807aacf1256a64b89f3f7b89ae805c43"
第二,部署本地Python环境跑。
代码语言:javascript复制# 安装Airtest框架
pip install airtest
# 安装Poco框架;编写了Poco语句就需要安装
pip install pocoui
# 安装airtest-selenium框架;编写了airtest-selenium语句就需要安装
pip install airtest-selenium
# 运行自动化测试脚本
python -m airtest run "D:pythonhelloworld.air" --device android://127.0.0.1:5037/127.0.0.1:7555 --log "C:UserszhangsanAppDataLocalTempAirtestIDEscripts807aacf1256a64b89f3f7b89ae805c43"
详见:如何脱离AirtestIDE跑自动化脚本 。
【参考】 https://www.jianshu.com/p/3e3ad243f956 Airtest引用其他的.air脚本 https://blog.csdn.net/Py_csdn_/article/details/109023773 【AirTest】引用别的.air脚本中封装好的方法的几种方式 https://blog.csdn.net/laoxi_liu/article/details/104628765 Airtest 常用函数(持续更新) https://blog.csdn.net/qq_42293487/article/details/102929123 airtest常用按键 https://www.cnblogs.com/songzhenhua/p/15612620.html Airtest API精讲之wait(),exists() https://blog.csdn.net/George513/article/details/101058574 Airtest-Poco元素定位剖析 https://blog.csdn.net/AirtestProject/article/details/105836667 poco的元素定位搞不定?速来看看这3个选择器 https://blog.csdn.net/qq_48946910/article/details/108640705 airtest有很多同名节点时快速定位到的一个方法 https://blog.csdn.net/AirtestProject/article/details/125999073 Airtest脚本的点击位置与点击偏移 https://cuiqingcai.com/9529.html Airtest 和 Poco 的 API 总结 https://www.cnblogs.com/songzhenhua/p/15970453.html Poco元素定位和脚本编写顺序 https://juejin.cn/post/7028783863102963720 一文打包Airtest干货教程-2021篇