AirtestProject 如何脱离 AirtestIDE 跑 Airtest 自动化脚本
此文章来源于项目官方公众号:“AirtestProject”
版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途
1. 前言
新手同学往往会借助 AirtestIDE 编写/运行自动化脚本;但是熟练 Airtest 和 Poco 框架之后,我们完全可以脱离 AirtestIDE 编写/运行脚本。
本文将详细讲述脱离 AirtestIDE 跑脚本的 2 种方式和注意事项,感兴趣的同学可以认真阅读下述内容哦!
2. 使用命令行跑自动化脚本
1)根据 IDE 的运行脚本命令跑
我们使用 IDE 自带的环境跑脚本时,在 log 查看窗的顶部会刷出运行当前脚本的一条命令,我们可以直接复制该命令去命令行终端运行:
直接只用此条命令运行脚本,实际上我们还是利用了 AirtestIDE 自带的环境跑脚本,好处是我们无需额外部署本地 Python 环境 :
但这里有一个小细节需要注意下,如命令行中包含类似&&
这样的字符,是需要转义的:
# 特殊字符在Windows下的转义
&&-->^&^&
# 特殊字符在Mac下的转义
&&-->/&/&
如果 不转义的话,最终结果是命令行被截断 ,如图中所示,尽管我们的运行命令是指定了 log 保存路径的,但是仍提示我们do not save log
,这是因为该命令从特殊字符&&
之后,就被截断了。
并且我们还会在最后的运行 log 中,看到类似 ‘ori_method’ 不是内部或外部命令,也不是可运行的程序
这样的提示:
或批处理文件
加上转义之后,就不会出现命令行被截断的情况了:
2)部署本地 Python 环境跑
除了使用 AirtestIDE 自带的 Python 环境跑脚本之外,我们还可以部署本地的 Python 环境来跑脚本。
首先我们要准备一个合适的 Python 环境,大于 Python3,小于等于 Python3.9 均可。
然后就在这里 Python 环境里面,像安装其它 Python 第三方库一样,安装我们的自动化测试框架:
# 安装Airtest框架
pip install airtest
# 安装Poco框架;编写了Poco语句就需要安装
pip install pocoui
# 安装airtest-selenium框架;编写了airtest-selenium语句就需要安装
pip install airtest-selenium
如安装第三方库过程中,出现报错或者超时,请先确保自己的 Python 版本是在支持范围之内的,然后再 使用清华源或者其它国内源安装 :
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple airtest
成功安装之后,我们可以使用 pip list 命令,查看我们的安装情况及框架版本信息:
(PS: 不能同时安装poco
与pocoui
,俩者会产生冲突!)
接下来,我们就可以在这个环境里面运行我们编写好的自动化脚本了:
airtest run "D:\test_plu\song.air" --device android://127.0.0.1:5037/127.0.0.1:7555 --log "D:/test/test01\ed879c1f10fa732db3e5e2c417ca7221"
# 或者
python -m airtest run "D:\test_plu\song.air" --device android://127.0.0.1:5037/127.0.0.1:7555 --log "D:/test/test01\ed879c1f10fa732db3e5e2c417ca7221"
使用命令运行脚本和生成 Airtest 报告的内容可以参考我们的往期推文 Airtest 报告 “全攻略”。
3. 使用其它编辑器跑自动化脚本
这里以常见的 Python 编辑器,pychram 为例,详细讲述该如何使用这款编辑器编写/运行自动化脚本。
1)环境部署
我们在 pycharm 新建项目之后,就需要为该项目设置 Python 解释器;pycharm 支持我们直接设置本地安装好的 Python 作为解释器,也支持使用虚拟 Python 环境作为解释器。
这 2 者的差别是,如果我们直接设置本地安装好的 Python 作为解释器,那么本地 Python 安装的所有第三方库都会导入进来为这个 pycharm 项目所使用:
但如果我们是新建了一个虚拟环境的话,则是基于本地的某个 Python 解释器,复制了一个不带任何第三方包的干净的 Python 虚拟环境,意思是已经安装到这个本地 Python 解释器中的所有第三方包都不会复制过来:
这也是很多同学刚开始使用 pycharm 的时候,明明在本地 Python 环境已经安装好了需要的第三方库,到了 pycharm 却仍旧找不到第三方库的原因。(需要注意是否是因为使用了虚拟环境)
那在 pycharm 安装第三方库的方式,就非常简单了,在项目使用的 Python 解释器里,点击右侧的+
号,输入想要添加的包名,然后点击 安装包
按钮即可:
环境部署好之后,我们就可以着手在 pycharm 编写/运行脚本了。
以 直接从 AirtestIDE 复制脚本到 pycharm 运行 为例,我们详细了解下有哪些内容我们需要特别注意下的:
2)log 保存
首先是脚本运行的 log 内容保存,我们在 AirtestIDE 编写和运行脚本,没有考虑过这个问题,是因为 AirtestIDE 会自动帮我们保存脚本运行的 log 内容,默认路径是 选项--设置--Airtest--默认Log存放路径
里设置的路径:
把代码复制到 pycharm 运行时,如需保存 log 内容(为后续生成测试报告做准备),我们就需要手动添加上这块的内容:
# 在auto_setup接口里设置logdir,用于保存log内容
# logdir可以传入具体的log保存路径,或者是True,传入True表示在当前项目目录下生成log内容
auto_setup(__file__,logdir=True)
log 内容往往包含一些报告所需的步骤截图和一个 log.txt
文件。
3)设备连接
第二个常见的问题,就是在 AirtestIDE 里,只要设备连接窗口已经连接上指定设备,我们在.air
脚本中无需额外处理,运行.air
脚本时,就会自动连接设备窗口的当前设备来跑脚本。
而 pycharm 显然不会帮我们处理设备连接的工作,所以我们需要在脚本中连接上待测设备:
# 在auto_setup接口传入devices参数
auto_setup(__file__,logdir=True,devices=["android://127.0.0.1:5037/127.0.0.1:7555"])
当然,我们还有非常多的接口可以用于连接我们各种待测设备,这里不一一举例,感兴趣的同学可以参考我们的往期推文 用 1 行代码搞定自动化测试的设备连接问题 。
4)图片路径
在 AirtestIDE 截取的图片,默认的路径都是相对路径,保存在.air
脚本下,与.py
文件同路径:
touch(Template(r"tpl1638179990578.png", record_pos=(0.179, -0.57), resolution=(810, 1440)))
但复制到 pycharm 执行时,相对路径大概率会发生变化,导致后面同学们运行时,经常出现 airtest.aircv.error.FileNotExistError: File not exist: tpl1638179990578.png
的报错。
此时我们要么修改成正确的相对路径,要么修改成绝对路径,只要保证 pycharm 能按你设定的路径找得到你的脚本截图即可:
touch(Template(r"D:\test_plu\song.air\tpl1638179990578.png", record_pos=(0.179, -0.57), resolution=(810, 1440)))
5)文件引用路径
很多同学会在自己的自动化脚本里面,调用一些公共脚本,可能是.air
脚本,也可能是.py
脚本等。
假设我们有如下几个脚本,各脚本的存放关系如下:
如果我们要在 song.air
脚本里面,调用 common.air
脚本 和 im_ex.py
脚本,可以这么编写脚本:
其中,调用 .air
脚本,我们可以使用 Airtest 提供的专用接口 using
;调用 .py
脚本,就与标准 Python 无异,直接 from ... import ...
即可。
但当我们在 pycharm 中打开 song.air
并且运行之后,会发现在 AirtestIDE 可以运行的脚本,到 pycharm 就找不到模块了:
我们可以通过手工添加 sys.path
的方式,让 pycharm 能找到 common.air
脚本:
6)报告生成
最后一个需要注意的内容就是报告生成啦,在 AirtestIDE 运行完.air
脚本之后,我们可以直接点击 查看报告
按钮,迅速生成并且打开 HTML 格式的测试报告。
但 pycharm 并没有这个功能,所以我们需要生成 Airtest 报告的话,只能在脚本中编写生成测试报告的语句:
# -*- encoding=utf8 -*-
__author__ = "AirtestProject"
from airtest.core.api import *
from airtest.report.report import simple_report
auto_setup(__file__,logdir=True,devices=["android://127.0.0.1:5037/127.0.0.1:7555"])
touch(Template(r"tpl1638243250870.png", record_pos=(-0.362, 0.13), resolution=(810, 1440)))
simple_report(__file__,logpath=True)
使用脚本生成 Airtest 报告,有很多注意事项:
- 报告生成语句要放在具体脚本的后面,防止未运行具体步骤就生成了空的测试报告
- 当脚本中包含 poco 或者 airtest-selenium 语句时,需添加对应的报告插件
plugins
- 不论中间的步骤运行成功与否,都生成测试报告,我们可以使用
try-finally
语句 - 需要生成测试报告,就必须保存 log 内容,因为报告的生成依赖于 log 内容
- 如需将报告发送给别人查看,需要在生成报告的语句中添加导出参数,只有导出报告才能发送给别人查看
更多关于使用脚本生成测试报告的内容,可以参考我们的往期脚本 Airtest 报告 “全攻略”,看完直接用脚本生成、导出报告,真香! 。
Airtest 官网:https://airtest.netease.com/
Airtest 教程官网:https://airtest.doc.io.netease.com/
搭建企业私有云服务:https://airlab.163.com/b2b
官方答疑 Q 群:654700783
呀~这么认真都看到这里啦,帮忙点击左下角的爱心,给我点个赞支持一下把,灰常感谢~