AirtestProject 如何脱离 AirtestIDE 跑 Airtest 自动化脚本

fishfish-yu · 2021年11月30日 · 1262 次阅读

此文章来源于项目官方公众号:“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: 不能同时安装pocopocoui,俩者会产生冲突!)

接下来,我们就可以在这个环境里面运行我们编写好的自动化脚本了:

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

呀~这么认真都看到这里啦,帮忙点击左下角的爱心,给我点个赞支持一下把,灰常感谢~

暂无回复。
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册