Skip to content

快问快答(第2期)

27.如何清空输入框的文本

Airtest的方式:

for i in range(10):
    keyevent("67")

# 或者
for i in range(10):
    keyevent("KEYCODE_DEL")

Poco的方式:

# 将输入框内容设置为空字符串,poco("xxx")为输入框的元素定位语句
poco("xxx").set_text("")

28.设备的3种状态:device、unauthorized、offline

1)device:设备在线可连接

通常情况下,我们使用 adb devices 命令在命令行查看与本机连接的设备详情,或者在Airtest IDE的设备连接窗口查看当前设备列表时,只有设备状态为 device 的设备,才是与本机正常连接且可通讯的设备:

image

2)unauthorized:未允许USB调试

如果开启了手机的 USB调试 选项并且用USB线连接好了设备和电脑,却发现设备状态为 unauthorized ,则表示未处理 允许USB调试 的弹窗,允许该弹窗即可:

image

3)offline:设备掉线不可用

常见于2种设备连接情况:

一种是连接模拟器设备,模拟器未启动完全就使用 adb connect 命令连接或者使用过程中模拟器挂了,都会出现模拟器的状态为 offline 的情况。这时候只要重新使用 adb connect 命令再次连接模拟器即可。

另外,也可能是模拟器自带的adb版本与Airtest自带的adb版本不一致,发生了冲突,导致adb连接出现问题,也会造成模拟器的状态为 offline 。这时需要将2个不一样版本的adb统一成一个相同的版本即可。

第二种情况常见于真机的无线连接。WiFi波动导致设备断连,出现 offline 状态,则需要重新执行 adb connect ip:port 。如还不能解决,则需要将无线连接的所有步骤重来一次,真机无线连接的教程可以参考:https://airtest.doc.io.netease.com/IDEdocs/device_connection/1_android_phone_connection/#3 。

29. no moudle named 'poco.drivers'

如在运行脚本过程中出现 no moudle named 'poco.drivers' 的报错,则表示当前python环境误装了poco库,未安装pocoui库。

需要注意的是,poco框架的库名为pocoui ,并不是poco,此时需要卸载掉poco库,安装正确的pocoui库即可:

pip uninstall poco
pip install pocoui

30.安装指定版本的库

命令如下:

pip install -U airtest==1.1.6

31.使用IDE截图特别模糊如何处理

如果同学们发现使用IDE截出来的图片非常模糊,可以尝试在AirtestIDE的 选项--设置 中,把 手机设备显示分辨率 调成2000,之后再重新连接设备,查看截图清晰度是否有所改善。

如未改善,还可以查看设备连接窗口的设备画面是否清晰,如还是非常模糊的话,可以先断开连接,然后在 conncet 之前勾选 use javacap ,之后再尝试截图。

32.如何判断当前该选用哪种poco模式

IDE的poco辅助窗内,给同学们提供了多种poco模式:

image

其中,如果我们测试的是安卓原生应用,则选取其中的Android模式即可,安卓的微信小程序也是选择此模式,且该模式不需要应用额外接入poco-sdk;

如果我们测试的是iOS原生应用,则选取其中的iOS模式即可,但目前不支持测试iOS微信小程序,所以iOS模式仅适用于测试iOS原生应用的情况,应用也无需额外接入poco-sdk;

其余模式,如unity、UE4、Cocos-lua等,指的是所测游戏项目的引擎类型,使用这些模式时,要求在游戏项目中接入对应的poco-sdk,并且打出项目包安装在设备上之后,才能使用,比如使用unity模式获取unity游戏项目的控件树:

image

33.如何安排脚本初始化、poco初始化和启动应用的顺序

很多新手在使用poco的时候,都容易把连接设备、初始化poco和打开应用的脚本顺序搞乱,导致出现一大堆奇妙的报错。

比如大家最常见的:“远程主机强迫关闭了一个现有的连接”“socket connection broken” 等等。

最正确的顺序是:先连接设备(一般在 auto_setup 接口里面连接)--> 再打开应用(一般用 start_app 接口)--> 等应用开启完毕,最后才初始化 poco

# -*- encoding=utf8 -*-
__author__ = "Airtest"
from airtest.core.api import *

# 连接设备
auto_setup(__file__,logdir=True,devices=["Android://127.0.0.1:5037/emulator-5554?cap_method=JAVACAP"])

#启动应用
start_app("com.NetEase")
sleep(6.0)

# 初始化poco
from poco.drivers.unity3d import UnityPoco
poco = UnityPoco()

poco("btn_start").click()

所以同学们在初始化poco的时候,千万记住要检查下这几条代码的顺序,避免产生不必要的报错。

34.同一个脚本初始化多个poco

在同一个脚本内,支持初始化多个不一样的poco,比如 Android poco 和 unity poco,就是可以共存的:

image

from airtest.core.api import *

auto_setup(__file__,devices=["android://127.0.0.1:5037/emulator-5554?cap_method=MINICAP_STREAM&&ori_method=MINICAPORI&&touch_method=MINITOUCH"])

from poco.drivers.android.uiautomation import AndroidUiautomationPoco
A_poco = AndroidUiautomationPoco(use_airtest_input=True, screenshot_each_action=False)

sleep(1.0)

A_poco("poco").click()
sleep(2.0)

from poco.drivers.unity3d import UnityPoco
U_poco = UnityPoco()

U_poco("btn_start").click()

但是我们不能在同一个脚本内,反复初始化相同的poco,比如多次初始化Android poco,就有可能导致奇奇怪怪的错误出现。

35.指定python环境安装第三方库

很多情况下,同学们的电脑里面可能安装了不止一个python环境,比如同时存在python2和python3,要在指定的python环境下安装第三方库,可使用如下命令:

python3 -m pip install airtest # 在python3环境下安装airtest库
python2 -m pip install airtest # 在python2环境下安装airtest库

除了从命令层面来区分以外,更直接的办法是同学们自己去对应的python目录下,用那个目录下的pip.exe来安装。

36.三个备选的连接参数

1)备选参数在哪里选择

在AirtestIDE的设备连接窗口中,点击connect连接设备之前,单击connect右侧的下拉按钮,即可找到3个连接设备的备选参数:

image

2)3个备选参数分别代表什么意思

① 第一个 Use javacap ,是给部分无法正常看到手机画面、minicap初始化失败 的手机或设备用的,所以模拟器看到黑屏、部分特殊的平板等设备可以考虑勾选这个选项

② 第二个 Use ADB orientation 是用于 屏幕旋转 的,如果在安卓手机屏幕旋转方向检测有问题、或者是部分特殊的平板无法显示正确的屏幕方向时可以勾选

③ 第三个 Use ADB touch 是 发送adb指令来点击屏幕 ,效果很差,速度也很慢,不建议勾选,只有在 部分无法点击屏幕的特殊安卓设备 上才需要使用(例如智能后视镜、特殊型号的平板等设备上) 正常情况下,手机都可以点击,如果无法被点击(比如小米设备),一般都是因为手机设置有选项漏了打开,特别是小米设备要注意 开启允许模拟点击 的设置

3)是不是把备选参数全带上就能适配所有设备

正常情况下,同学们连接设备是不需要勾选任何备选参数的,我们也不建议大家主动把所有备选参数都勾选上,因为这些备选参数会影响设备连接和使用的效果。

除非是上述提到的特殊情况,比如无法使用minicap的设备,可以通过勾选 use javacap 来连接;常见的需要勾选备选参数的设备,MIUI12的小部分型号,部分模拟器,部分特殊安卓设备等。

4)如何在脚本中添加备选参数

如在IDE连接设备时,勾选了一些备选参数,则同学们在脚本中连接该设备,也要添加对应的备选参数。特别是使用此类设备在命令行运行脚本时,千万要记得将参数加在设备连接字符串上:

# 添加了3个备选参数的1个安卓设备
Android://127.0.0.1:5037/79d03fa?cap_method=JAVACAP&&ori_method=ADBORI&&touch_method=ADBTOUCH

37.Airtest的多图查找

Airtest没有提供专门的API给我们进行多图查找,但是我们可以用简单的语法来实现:

picList = [pic1,pic2,pic3]  # 截图的图片对象列表
for pic in picList:
     pos = exists(pic)
     if pos:
         touch(pos)
         break  # 只要找到图片列表中的任何一张图片,就执行touch

38.poco的多元素查找

poco有专门的API实现了多元素等待:

# 等待多元素其中的任意一个元素出现
bomb = poco("bomb")
yellow = poco("yellow")
blue = poco("blue")

while True:
    fish = poco.wait_for_any([bomb,yellow,blue])
    print(fish.get_name())

# 等待多元素的所有元素都出现
poco.wait_for_all([yellow,blue,black])

39.'NoneType' object has no attribute xxxx

这个报错可能出现在不同的方法里面,比如:

AttributeError: 'NoneType' object has no attribute 'snapshot'

AttributeError: 'NoneType' object has no attribute 'start_app'

出现这些报错,基本上都是因为同学们在脚本中没有连接设备,所以只要在脚本开头,补充上连接设备的脚本即可。

40.怎么获取Windows窗口的句柄

1)在IDE的log窗口查看

在IDE中连接上该Windows窗口,然后随便运行1个自动化脚本,我们可以在log查看窗的最上面,看到运行该脚本的命令,其中包含Windows窗口的句柄:

image

2)使用网上的工具查看

使用VC或者VS里面tool中的SPY++,也可以查看窗口的句柄、名字、类、类型、大小和位置等。还有其它的一些方法和工具可以自行百度。

41.UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)

编码报错,一般情况下我们可以通过在脚本开头声明编码来规避这个问题:

# -*- encoding=utf8 -*-

如该声明无效,脚本运行到某些 print 中文的语句中,还是会报这个错误,可以单独指定这个中文的编码:

s = '中文'
print(s.decode('utf-8'))