测试十五、使用命令行终端运行脚本
本文最后更新于:2023年10月19日 晚上
十五、使用命令行运行脚本¶
我们的脚本在编写完成后,除了使用 AirtestIDE
运行之外,也支持脱离IDE,直接使用命令行运行脚本。
1. 使用AirtestIDE命令行运行¶
即使本地没有安装python
环境,或是没有安装 airtest
与 poco
,我们也一样能够使用命令行来运行脚本,诀窍就是复制在 AirtestIDE
里运行脚本时log窗口里显示出来的命令行:
将运行脚本时 AirtestIDE
生成的这段命令行代码复制到你的命令行终端里,回车运行就可以了。
请 注意 , 这种使用AirtestIDE命令行来运行脚本的方式,是一个简单快速的方式,假如想要批量执行、同时执行的话,可能会遇到效率不佳的问题。若有长时间或批量执行脚本的需求,请尽量在本地Python环境安装airtest和poco来执行脚本,详情下文。
2. 在本地环境使用命令行运行脚本¶
方法1中介绍的使用AirtestIDE命令行来运行脚本,虽然很方便,但是不适合更复杂的操作(例如想同时用多个命令行运行多台手机、多个脚本等情况),以及对于一些Python开发者来说,可能需要在脚本中使用其他功能强大的Python第三方库。因此我们更加推荐在本地python环境中安装airtest和pocoui,然后用命令行运行脚本。
关于 如何部署python环境 ,我们已经在上2节的内容详细介绍过,这里不再赘述。
本地python环境部署完成后,我们就能够脱离AirtestIDE,在该python环境上运行我们的自动化脚本了。
1)命令行运行脚本的示例¶
我们可以使用 airtest run + 脚本路径
这样的命令来运行我们的airtest脚本,以下是使用命令行运行的例子:
1 |
|
这两个命令行的效果是相同的,我们用airtest运行了一个叫做 untitled.air
的脚本,传入了 --device
和 --log
两个参数,分别是我们的手机设备和log输出目录。
2)airtest run 命令的参数介绍¶
airtest run
命令必须传入的参数是指定脚本的路径,其他可选参数有:
--device
:指定设备字符串--log
:指定log输出目录--compress
:指定截图精度,取值范围[1,99],精度越高截图越清晰--recording
:设置运行脚本过程录屏(airtest1.1.6之后可以在该参数后设置录屏文件名)--no-image
:设置运行脚本过程不截图(airtest1.1.7新增)
我们还可以查阅 Airtest-running-air-from-cli 文档来了解这几个参数的详细信息。
更多运行脚本的命令示例:
1 |
|
3)设备字符串介绍¶
在刚才的命令行中使用的 --device
参数,传入的是一个设备字符串,以安卓设备为例,字串完整定义如下:
1 |
|
其中,adbhost是adb server所在主机的ip,默认是本机127.0.0.1,adb port默认是5037,serialno是android手机的序列号。更多adb的方面的内容请参考文档 ADB 。这里的设备字符串,可以是安卓设备、iOS设备,或者是Windows窗口等:
① 安卓设备字符串¶
1 |
|
在 Android连接常见问题 中,我们提到了部分设备由于较为特殊,需要在连接时勾选 use ADB orientation
或是 use javacap
等特殊连接选项后才能连接手机,这些设备在使用命令行运行脚本时,也同样需要将这些参数附加在设备字符串后面:
1 |
|
注意:命令行中如果有出现 ^ < > | &
这些字符,可能都需要转义才能生效,因此如果连接字符串中需要写 &&
时,在windows下需要改写成 ^&^&
,添加一个 ^
符号进行转义,即:
1 |
|
未对特殊字符进行转义最常见的错误就是导致命令行被截断,举个例子,同学们在命令行运行脚本时,非常容易使用下述类型的命令:
1 |
|
直接在Windows终端运行该命令,会提示 do not save log
,这很奇怪是把,明明我这条命令里面已经使用 --log
参数,指定了log保存路径了,为何还提示我没有保存log呢?!这其实就是因为这条命令里面包含 &
这个特殊字符,但是我们又没有转义,导致命令被截断了,所以同学们一定不能忘记特殊字符需要转义的问题。
② iOS设备字符串¶
1 |
|
③ Windows窗口字符串¶
1 |
|
值得一提的是,windows窗口的连接使用了 pywinauto 库,在AirtestIDE中默认是使用当前已连接到IDE里的窗口句柄来连接的。可以预想到,假如窗口关闭了,下一次再开启时,句柄就可能发生变化。因此我们的连接字符串支持了 pywinauto
的 connect
接口去连接窗口,查阅 参考文档 里的几种参数填写方式来写连接字符串的参数部分:Windows:///?name=value
。
注意
如果自己拼写的设备字符串无法正确连接设备,但是在AirtestIDE中可以正常连接的话,可以考虑先在AirtestIDE中运行一次脚本,然后将运行时自动生成的命令行里 --device Android:///
参数复制出来,即可在代码中使用了,这种做法可以极大程度避免设备字符串编写错误的问题。
4)对脚本运行过程进行录屏¶
在 Android设备 上运行脚本时,我们可以在运行脚本的命令行中,通过添加一个 --recording
参数,让airtest自动对脚本执行过程中的手机屏幕进行录制操作。(运行结束后,录屏文件会默认保存在log文件夹里面,使用 recording_手机序列号
来命名录屏文件)
1 |
|
并且airtest1.1.6支持 在 --recording
参数后面加上一个文件名来命名录屏文件 ,例如 --recording test.mp4
,如果有不止一台手机在运行,会把文件命名为 手机名_test.mp4
。下述示例使用 --recording 123.mp4
指定录屏文件名为 123.mp4
:
1 |
|
另外我们需要注意下,传入的录屏文件名必须以 .mp4
作为结尾!
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!