AirtestProject 答疑第四期 | 使用 Airtest 最常见的 8 大问题
此文章来源于项目官方公众号:“AirtestProject”
版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途
前言
本期答疑目录:
- 1.如何取消脚本执行过程刷新的大量 log 信息
- 2.IDE 自带的查看应用包名的功能
- 3.IDE 的脚本编辑和 log 查看窗口显示空白
- 4.webdriverAgentRunner 报
NSInaliArgumentException
- 5.Airtest 版本为 1.1.3,部分手机出现录屏失败
- 6.输入密码时 Airtest 不显示密码键盘
- 7.如何模拟鼠标右键
- 8.局部截图/区域截图
1.如何取消脚本执行过程刷新的大量 log 信息
在脚本运行的时候, Airtest 默认会刷新很多 log 信息,如下图所示:
如果你不想这些 log 信息干扰你提取有效的报错信息时,你可以在脚本代码开头加上 log 级别的设定:
# -*- encoding=utf8 -*-
__author__ = "user"
import logging
logger = logging.getLogger("airtest")
logger.setLevel(logging.ERROR)
from airtest.core.api import *
auto_setup(__file__)
这样运行时只会在初始化手机时会有少量 log 输出,初始化完毕后就能够对 logger 进行过滤了。
2.IDE 自带的查看应用包名的功能
大家经常会使用 start_app("包名")
来启动待测应用,而这个包名需要我们用命令去获取。
实际上,我们还可以通过 IDE 自带的一个 Android 助手 ,帮助我们快速获取已连接设备上的应用包名。
连接上待测的安卓设备以后,点击右上角的手机助手,然后再点击 打开 Android 助手 选项:
之后我们就可以在弹出的窗口中查看到设备上的应用包名:
另外,我们还可以在设备上打开想要获取包名的应用,之后点击安卓助手右下方的 refresh
按钮,即可看到当前打开应用的 package
和 activity
:
3.IDE 的脚本编辑和 log 查看窗口显示空白
有些同学在启动 IDE 后,发现不能够看到脚本编辑窗口和 log 查看窗口中的文字,就像下图这样:
包含启动后闪退在内,这些问题大概率都是由显卡兼容性问题导致的。我们可以通过双击文件夹中的 兼容性模式启动.bat
脚本就能够正常启动 AirtestIDE。
并且,在 1.2.3 版本的 IDE 中,我们在设置中新增了一个选项:
默认情况下会选择 default
模式。如果启动有问题的用户,可以尝试选中下拉菜单中的另外三个选项,并且重启 AirtestIDE,查看接下来是否能正常显示脚本编辑窗口和 log 查看窗口。
如果能够生效,未来启动 AirtestIDE 时都将会以这个配置项来启动,无需每次都手工双击 兼容性模式启动.bat
脚本来启动 AirtestIDE 了。
4.webdriverAgentRunner 报NSInaliArgumentException
出现这个错误的原因大多是使用了 11.4.1 版本的 xcode:
目前(2020-05-12)这个版本的 xcode 还不兼容,根据最近一次的更新,xcode 和 iOS 的支持情况如下,只要将 xcode 换成兼容版本即可:
5.Airtest 版本为 1.1.3,部分手机出现录屏失败
使用 1.1.3 版本的 Airtest,部分手机用 --recording
参数对设备进行录屏操作时,会出现如下报错:
这些手机需要点开安装好的 Yosemite.apk
,然后给一个开启录屏的权限。(1.1.3 版本的录屏操作由 Yosemite
完成)。
6.输入密码时 Airtest 不显示密码键盘
有同学反馈,脚本运行到输入密码时,手机弹出了安全键盘,但是在 Airtest 中却不显示这个安全键盘,这是为什么?
其实这个是正常现象,Airtest 不会录制有安全键盘的画面,但是各种输入操作还是正常进行的。
7.如何模拟鼠标右键
pywinauto.mouse
这个模块给我们提供了各种模拟鼠标操作的方法,例如大家常问的右键操作,就可以使用这个模块的 right_click()
方法:
首先我们需要获取当前连接的窗口,然后再调用 right_click()
方法实施鼠标右键点击操作:
from airtest.core.api import *
auto_setup(__file__)
# 获取当前连接的窗口
dev = device()
# 拿到鼠标,并模拟鼠标的右键点击操作
dev.mouse.right_click(coords=(1920,100))
更多模拟鼠标或者键盘的操作,可以参考我们往期的推文: “如何用 python 模拟鼠标和键盘的操作” 。
8.局部截图/区域截图
局部截图或者说按坐标截图是大家经常会问到的问题,Airtest 提供了 crop_image(img, rect)
方法可以帮助我们实现局部截图:
举个例子,我们想要截取手机屏幕中被红框圈中位置的截图:
我们可以这么实现:
# -*- encoding=utf8 -*-
__author__ = "AirtestProject"
from airtest.core.api import *
# crop_image()方法在airtest.aircv中,需要引入
from airtest.aircv import *
auto_setup(__file__)
screen = G.DEVICE.snapshot()
# 局部截图
screen = aircv.crop_image(screen,(0,160,1067,551))
# 保存局部截图到log文件夹中
try_log_screen(screen)
结果如图:
Airtest 官网:airtest.netease.com/
Airtest 教程官网:airtest.doc.io.netease.com/
搭建企业私有云服务:airlab.163.com/b2b
关注下方公众号,可以查看更多往期教程,回复 “交流群” 可以加入我们的官方开发者交流群