AirtestProject 更新公告:Airtest 更新至 1.2.10.2 版本

fishfish-yu · 2023年06月15日 · 3075 次阅读

此文章来源于项目官方公众号:“AirtestProject”
版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途

1. 前言

本次是 Airtest 库更新,版本提升至 1.2.10.2,内容主要是 Android 录屏功能的改动。

2. 更改部分

  • 在 Airtest1.2.9 中提供的cv2模式已经被舍弃,因为容易引发错误,效果也不如ffmpeg

  • 只有 Android 需要mode参数,默认为yosemite模式;Window/iOS 的start_recording 不再需要有mode参数;

  • 录屏的ffmpeg模式增加了max_size参数,能够指定录屏结果的图像大小,因为屏幕图片越大,在录屏时造成的系统负载越大(CPU 和内存占用);

代码示例:

dev = connect_device("android:///")
dev.start_recording(output="test.mp4", mode="ffmpeg", max_size=800)  
# Android 支持mode指定使用ffmpeg模式

3. 其他改动

  • 去掉了 numpy 的版本号限制

  • 如果 Android 出现了屏幕有一半黑屏的情况,可以再次重连

4. 如何更新

1)使用本地 python 环境的同学

可以直接更新本地 python 环境的 Airtest 库:

pip install -U airtest

2)使用 AirtestIDE 的同学

目前最新的 Airtest1.2.15 内置 Airtest 版本为 1.2.10,所以我们只能在 AirtestIDE 中设置使用本地 python 环境,之后将本地 python 环境的 Airtest 更到最新的 1.2.10.2 来体验新版:

5. Android 录屏功能介绍【重点】

1.2.10.2 版本的 Airtest 支持 2 种录屏模式,yosemiteffmpeg默认情况下,都是使用yosemite录屏模式

1)如何选择合适的 Android 录屏模式

上述两种录屏模式的区别如下:

  • yosemite :原有的默认模式,录屏清晰度和质量较高,但兼容性较差,部分机型可能有问题;

    • 支持的参数:max_time, orientation, bit_rate, bit_rate_level
  • ffmpeg : 在 1.2.9 之后加入的新模式,录屏帧率和质量较低,但兼容性更好,能兼容绝大多数设备;

    • 支持的参数:max_time, orientation , max_size,fps, snapshot_sleep

由此可见,如果对录屏清晰度有要求的话,可以使用默认的录屏模式 yosemite (前提是设备能使用这种录屏方式),不用额外指定录屏模式的参数;

如果对录屏清晰度没有很高要求的话,可以指定录屏模式为 ffmpeg

dev = connect_device("Android:///")
dev.start_recording(mode="ffmpeg",output="test.mp4")
pass
dev.stop_recording()

2)重要参数:指定录屏时长 max_time

2 种录屏模式均有一个默认的录屏时长:1800s,也就是半小时;用户可以自由修改这个默认的录屏时长:

dev = connect_device("Android:///")
dev.start_recording(max_time="10",output="test.mp4")
sleep(11)

示例没有结束录屏的脚本,则会按照启动录屏时的 max_time 时长去录屏,也就是录屏 10s 后就自动结束录屏了。

但是这里有一点比较特别:如果这种情况下,使用yosemite录屏模式,则录屏文件仍会保存在手机内存里,没有被拉取出来(添加结束录屏脚本可以解决);如果使用ffmpeg模式,则录屏文件会保存在 log 目录下。

所以,不论有没有特殊指定最大录屏时长,我们还是按照规范添加开启录屏和结束录屏的脚本,避免一些问题。

3)重要参数:指定录屏时屏幕方向 orientation

  • 当跑测过程中大部分时间是竖屏时,可以考虑将 orientation=1 ,或 orientation="portrait"

  • 当跑测过程中大部分是横屏,可以 orientation=2 ,或 orientation="lanscape" ,适合游戏等横屏应用;

  • 横竖屏都有可能的话,可以不指定参数,默认值为 0,会用一个正方形来容纳视频内容,方便横竖屏转换

示例详情可以参考我们的往期推文 Airtest 新增 iOS、Windows 录屏功能,真香!

4)重要参数:指定录屏的图像大小 max_size

录屏的ffmpeg模式有一个 max_size参数,能够指定录屏结果的图像大小:

# 指定录屏图像大小为800
dev = connect_device("Android:///")
dev.start_recording(mode='ffmpeg',max_time=10,output="test_800.mp4",max_size=800)
sleep(11)
# 指定录屏图像大小为1080
dev = connect_device("Android:///")
dev.start_recording(mode='ffmpeg',max_time=10,output="test_1080.mp4",max_size=1080)
sleep(11)

在相同设备,相同画面下录屏,运行后可以知道,图像大小为 800 的清晰度比 1080 的差,但录屏文件比 1080 的小。

由此可见,如果不介意录屏清晰度,但是比较介意录屏大小,可以适当调低 max_size ,节省内存。

6. 小结

今天重点介绍了 Airtest1.2.10.2 的改动内容,以及详细介绍了最新的录屏功能。

如同学们在使用新版的 Airtest 时遇到了一些问题无法解决,特别是录屏相关的问题,可以通过此网站向我们的开发者快速提单:https://airtest.netease.com/issue_create

可以在标题中加入 “Airtest1.2.10.2” 之类的字眼,方便我们快速筛选和排查。


Airtest 官网https://airtest.netease.com/
Airtest 教程官网https://airtest.doc.io.netease.com/
搭建企业私有云服务https://airlab.163.com/b2b

官方答疑 Q 群:117973773

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

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