Airtest步骤详解
录制脚本
touch:点击事件,在设备窗中选中对应图标,或者填入点击的坐标
swipe:滑动事件,选中图标滑动或填入滑动前后的坐标位置
sleep:等待事件,填入等待时间(单位是秒)
text:输入文本内容
keyevent:按键输入
data:image/s3,"s3://crabby-images/d2d0c/d2d0c6494ff6be7047419876d98d0bc3a3555d5b" alt="0"
执行部分代码
airtest支持执行部分代码
data:image/s3,"s3://crabby-images/9e52e/9e52e6c302edfdd3a2803ecc486f825436da8ec8" alt="0"
assert断言
assert_exists 断言存在
assert_not_exists 断言不存在
示例:assert_exists(Template(r"tpl1673339095160.png", record_pos=(0.0, 0.839), resolution=(540, 960)), "底边栏存在")
assert_equal 断言相等
assert_not_equal 断言不相等
注:如果判断数字,注意对比的是不是string类型
data:image/s3,"s3://crabby-images/642e4/642e4389519b42f8a16cf351824db9a0d8e97c66" alt="0"
断言失败
如果断言失败,代码行会报红,log里会抛出异常,程序中断执行,例如以下两种异常:
data:image/s3,"s3://crabby-images/321aa/321aab4703683e8bb323a6f5f77e7f4f62723799" alt="0"
data:image/s3,"s3://crabby-images/401d1/401d15bdd9188151842fa1887384f801f03a9a0b" alt="0"
运行脚本
方法:
按键F5
运行--运行脚本
菜单栏中三角形符号
停止运行
SHIFT+F5
菜单栏中正方形符号
运行--停止运行
查看运行报告
Ctrl+L进行保存,再文件夹中找到html文件,选择浏览器查看
注:部分浏览器打开后页面是错的,换成chrome或者IE是显示正常的
airtest报告对每一个事件都有记录,并对操作时间都有截图记录
data:image/s3,"s3://crabby-images/3c079/3c079837d3221948db43a84bbaae17922050b940" alt="0"
touch
data:image/s3,"s3://crabby-images/72097/720974f64bbe8005c9d5cb40e7348b312ea09a0b" alt="0"
touch(v, times=1, duration=0.01, right_ckick=False)
@param v: 图片或者坐标(x, y)
@param times: 点击次数,默认1次
@param duration: 按住时间,默认0.01秒
@param right_ckick: 右键点击(仅限windows模式)
如果不知道坐标,可以利用图片的返回return查看图片的中心坐标
如果右侧界面内找不到要点击的图片,会抛出如下异常:
data:image/s3,"s3://crabby-images/3356d/3356df927b237ba12a171cfcd20c2b57558bdb9b" alt="0"
wait
data:image/s3,"s3://crabby-images/ef89b/ef89b4257a3215126e0b5025c676061bd9f3bfdd" alt="0"
wait(v,timeout=TIMEOUT,interval=0.5,intervlfunc=func)
@v :图片
@timeout :等待匹配的时间间隔,默认为20s
@intervalfunc :匹配的图片未找到时,执行func函数
@interval :每次匹配的时间间隔,默认0.5秒(单位:秒)
@return :找到图片后返回图片中心坐标,没找到返回TargetNotFoundError
一般情况下,touch等事件的等待时间内足够页面加载完成,所以一般时候是不用wait方法的。
但如果查找页面元素的时间大于20s,就可以用到wait
data:image/s3,"s3://crabby-images/ef89b/ef89b4257a3215126e0b5025c676061bd9f3bfdd" alt="0"
data:image/s3,"s3://crabby-images/dd25e/dd25e1a2462ca63d4ca03b3ba50838e3f67adb3e" alt="0"
wait也可以和touch等结合使用,这种情况下,虽然代码只有一行,实际执行却是两步。示例如下:
data:image/s3,"s3://crabby-images/4f889/4f889fe8a4b52ebc562a31e34a554beeacb48089" alt="0"
data:image/s3,"s3://crabby-images/bdd2c/bdd2c82b977422d4cc4ead186648419ceee515f9" alt="0"
swipe
data:image/s3,"s3://crabby-images/bccd7/bccd74fefaa3301fcd822e25489424cdb35efe9c" alt="0"
swipe(v1, v2=None, vector=None, duration=0.01)
@v1:截图或者坐标(x,y)
@v2:截图或者坐标(x,y) 从v1滑动到v2 (优先级高于vector)
@vector:[x,y]录制时自动生成,记录屏幕的滑动比例,向右为x正向,向下为y正向
@steps:滑动步数。默认5步。
@duration:滑动的持续时间。默认0.5s。
以下两种格式都可以:
data:image/s3,"s3://crabby-images/673cd/673cdced196853eeb8362b2b1428fc7c8cbf0744" alt="0"
data:image/s3,"s3://crabby-images/2a804/2a804728216a581dc1e26eeb6f4a5b1f1a86aa04" alt="0"
exists
data:image/s3,"s3://crabby-images/1e7be/1e7bea4ad5744f3da640787fa71fc399119cbb82" alt="0"
exists用于判断图片是否存在,存在返回中心点坐标,不存在则返回false
data:image/s3,"s3://crabby-images/22563/225636475c10735871fd93a1693c65a830e3f584" alt="0"
data:image/s3,"s3://crabby-images/d29d0/d29d0e858adaa0ac25428201f6fb14bba4d016bd" alt="0"
text
data:image/s3,"s3://crabby-images/fee4e/fee4e02111f36029eab758aeb7ee6a7649aee623" alt="0"
@text :要输入的文本
@enter :完成输入后默认执行 Enter 操作 ,默认是 True
@search :完成输入后强制执行search 操作,默认是 False
data:image/s3,"s3://crabby-images/f2dc9/f2dc9f66e112db02b7d1c3532145a32c668adbe6" alt="0"
data:image/s3,"s3://crabby-images/eb37c/eb37c302e524e4986dc3a29d55261fc3c40b1ba3" alt="0"
keyevent
data:image/s3,"s3://crabby-images/70592/70592dcce7235c6bae4b79e13721aad3eda9cd1f" alt="0"
@keyname:按键名
data:image/s3,"s3://crabby-images/45f5a/45f5afaa13bdae40af4bcd6c245e368e15a21a14" alt="0"
data:image/s3,"s3://crabby-images/3bb2b/3bb2b135d2c1d96f2cbb7903508b5e64bcbd3b05" alt="0"
snapshot
airtest生成报告时,会自动带上截图,同时我们也可以使用snapshot添加截图
data:image/s3,"s3://crabby-images/a306b/a306baf6a97014cde47303b10e287953e159ddeb" alt="0"
@filename – 保存截图的文件名,默认保存路径为 ST.LOG_DIR中
@msg – 截图文件的简短描述,将会被显示在报告页面中
示例如下:
data:image/s3,"s3://crabby-images/1b644/1b6441670767366baa48c69f64334c7ddc071b66" alt="0"
data:image/s3,"s3://crabby-images/53914/539142c48cba4db59a8aa738de10ac0b1ecd9217" alt="0"
图片编辑器
对截取的图片双击,可以打开图片编辑器
data:image/s3,"s3://crabby-images/e052b/e052bcf447502e43e70afefd29b0a950b9adccba" alt="0"
Image Editor使用说明
左侧截屏功能区:
1、Snapshot&Recognition:截屏+自动识别
2、Show Help:显示帮助
3、鼠标滚轮:截屏功能区的图片缩放
4、鼠标双击:截屏功能区的图片自适应位置重置
5、鼠杯右键:更多交互
图像识别时会使用本界面中用户调节的识别参数,状态栏显示识别可信度
如果识别可信度低于设定的识别阀值,截屏上将不显示操作位置点的标记
右侧截图参数:
(l)filename:修改文件名,按Enter确认修改
(2)threshold:识别阈值,花围[0,1]。识别可信度低于此阈值的结果将被舍弃
(3)rgb:True、False,是否开启彩色识别
(4)target_pos:范围1-9,对应九宫格键盘位置
位置”0”与位置”"5”效果一致,均在图像中央位置
data:image/s3,"s3://crabby-images/30582/3058265a1be16c39eb5a49f68842b97a5ddf51f0" alt="0"
操作app
在不知道app包名时,可以用adb指令查看app报名
adb shell pm list packages
data:image/s3,"s3://crabby-images/714e9/714e947ceb6b004a1506fb58218b344f1c1f9e18" alt="0"
查看当前app包名和activity
adb shell dompsys window | findstr mCurrentFocus
data:image/s3,"s3://crabby-images/48310/4831044130fca95f92e1ca6299cd3888a410a824" alt="0"
打开app:start_app
start_app("com.taptap")
关闭app:stop_app
stop_app("com.taptap")
data:image/s3,"s3://crabby-images/17a42/17a4219b00bda804fad8f6dc026d07fbf1f81daa" alt="0"
data:image/s3,"s3://crabby-images/59efa/59efaa9191add4e391d717dee2351cf0562d601e" alt="0"
python环境下命令行执行airtest脚本
安装airtest库:pip install airtest
安装poco库:pip install pocoui
速度慢的话可以使用国内镜像源
命令行参数
data:image/s3,"s3://crabby-images/14ee5/14ee53b80a4f8d2aba64a6bff2623df423142893" alt="0"
通过图中可知,命令格式为:
AirtestIDE runner 脚本.air --device android://127.0.0.1:5037/emulator-5554(手机设备) --log 指定日志路径
其中,AirtestIDE 是执行工具
runner 脚本 是需要运行的脚本
--devide 是设备类型、ip、名称
--log 是指定日志保存的路径
Poco
Airtest是通过图像识别的方式找到想点击的位置进行操作的;
但在图像识别不够精准时,如游戏人物有动作时,可以使用基于UI控件搜索的方式,即Poco框架。
位置在界面左下角,默认选中stop,需要手动切换到对应平台
data:image/s3,"s3://crabby-images/831fe/831fedb969b255781ab37446fed071e36238c595" alt="0"
设备中会安装PocoService
data:image/s3,"s3://crabby-images/10d7f/10d7f2d9159c4df40e5f497f0e38a7a5de66e406" alt="0"
探索页面元素
点击右下Poco Inspector按钮,探索页面元素
data:image/s3,"s3://crabby-images/6106c/6106c3cb4f0304fc5206b4672237abcd354dbe8d" alt="0"
锁定
点击后锁定后,右侧页面进行操作时,页面不跳转。解锁后恢复正常
data:image/s3,"s3://crabby-images/4047e/4047e88f8d9293db292bb7b1d57d48081f064b89" alt="0"
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)