二、Android模拟器连接

1. 前言

如果我们手边没有可用的Android真机,又想进行Android应用自动化测试,这时候就要使用AirtestIDE的Android模拟器自动化测试功能了。

AirtestIDE所支持的模拟器包括 Android Virtual Device(AVD) 和市面上常见模拟器(如 Mumu模拟器 )。

模拟器可以像真机一样连接到AirtestIDE中,如果 画面显示为黑屏 ,请在连接模拟器之前,勾选connect按钮下拉菜单里的 Use javacap 选项,然后再点击connect 按钮进行连接。如果依然连接失败,可以尝试再勾选 use adb orientation 后连接。

2. mumu模拟器连接示例

这里以mumu模拟器为例, 展示一下模拟器的连接流程:

1)开启 允许USB调试 设置

首先,与手机类似,需要打开模拟器的 开发者选项-允许USB调试 。部分模拟器可能需要找到 设置-关于手机/关于平板 点击多次后才能打开开发者选项:

image

2)在模拟器中手动安装上 Yosemite.apk

IDE连接部分模拟器时,可能无法自动安装上Yosemite.apk,这里我们建议大家直接在模拟器中手动安装上这个应用,我们可以到AirtestIDE的下述目录下找到这个apk:

image-20210917174036465

3)在IDE中连接mumu模拟器

  • 打开AirtestIDE设备窗内的 远程设备连接 ,输入 adb connect 127.0.0.1:7555 后(该端口号与模拟器品牌相关,见 模拟器连接端口汇总 ),点击 连接 按钮

image

  • 设备列表中可见 127.0.0.1:7555 设备,直接点击右侧的Connect按钮即可成功连接。

image-20210917175759703

  • 完成连接:

image

3. 市面常见模拟器连接端口汇总

主流模拟器的设备连接代码如下:

模拟器adb连接代码
网易Mumuadb connect 127.0.0.1:7555
夜神adb connect 127.0.0.1:62001
雷电adb connect 127.0.0.1:5554
逍遥adb connect 127.0.0.1:21503
iToolsadb connect 127.0.0.1:54001
天天adb connect 127.0.0.1:6555
海马玩adb connect 127.0.0.1:26744
BlueStacksadb connect 127.0.0.1:5555

这些模拟器的连接过程均可参考上文中 mumu模拟器连接示例 的描述进行连接。

4. 连接Android原生模拟器(AVD)

1)安装Android环境:

搭建 Android Studio ,完成后在 Android Studio 中,选择 Tools > Android > AVD Manager

2)创建模拟器:

  • 创建设备界面:
    image
  • 选择设备:
    image
  • 选择系统:
    image
  • 配置页面填写如下:
    image
  • 设备创建完成,启动虚拟设备:
    image

3)在AirtestIDE连接模拟器:

  • AirtestIDE设备窗内将出现 emulator-555x 设备,点击 Conenct 按钮:
    image
  • 完成连接:
    image

5. 连接模拟器的常见问题

1)连接后部分模拟器显示黑屏

典型的例子是夜神模拟器,AirtestIDE连接夜神模拟器容易出现黑屏的情况,此时我们需要在 connect 之前点击右侧的下拉按钮,勾选上 use javacap 选项后再点击 connect 按钮连接,才能避免看到的屏幕是黑屏。

image-20210918103811492

2)需勾选2个备选参数的模拟器

典型的例子是逍遥模拟器,在部分版本的模拟器上,可能勾选了 use javacap 后依然连接失败,此时可以尝试再勾选 use adb orientation 选项后再重新连接即可。

image-20210918104014716

3)部分品牌模拟器出现无法点击的现象

部分品牌模拟器,可能出现无法正常点击的现象,可以尝试勾选 use ADBtouch 后再连接。

4)模拟器无法使用text()接口输入文字的情况

部分品牌模拟器(例如夜神),可能因为默认使用键盘输入,因此无法调用yosemite输入法,导致 text() 接口无法输入文字。可以先确认模拟器设置中,硬件-物理键盘 是否被勾选了, 取消勾选后再重新尝试即可。

image

如果依然失败(物理键盘选项被不断自动重置),可以打开右上角的模拟器设置,勾选软键盘选项后重试:

image

如果依然无法输入,可以考虑换用poco来输入(set_text()),或是直接使用adb指令输入英文内容,详见 文档

5)模拟器未安装Yosemite.apk导致连接失败

  • yosemite.apk 未安装也容易导致模拟器连接失败,一般会出现如下的报错;请检查模拟器上是否成功自动安装了 yosemite.apk,如果没有安装的话,检查开发者选项中是否默认阻止了通过USB安装应用,应该选择允许,然后在连接时IDE会自动向模拟器中安装该apk 如果还是装不上,可以在IDE目录下搜索一下这个apk文件,手工安装到模拟器中:

image

6)模拟器自带的adb.exe版本与Airtest的adb.exe版本冲突

有时候我们尽管已经在模拟器的设置里开启了USB调试,手动安装了Yosemite.apk,并且勾选了正确的参数,模拟器状态仍显示 offline ,或者连接时报 AdbError 等,我们可以优先排查下是否 未统一 模拟器自带的adb和airtest的adb版本,常见操作是用Airtest的adb文件覆盖掉模拟器的adb文件,需注意部分品牌模拟器的adb文件命名规则,替换后手动改成模拟器原有的命名规则。

另外,本地PC如有其他版本不统一的adb.exe也可能影响模拟器甚至本地Android真机的连接,请同学们一并统一成相同的版本。(目前Airtest自带的adb是40版本)

6. 在代码中连接Android模拟器

1)在命令行传入模拟器设备参数

如果在命令行运行脚本时,连接的是模拟器设备,有一点需要注意,因为我们在连接时有可能勾选了Use javacapUse ADB orientation这俩个选项,所以在命令行连接设备的时候,也需要把这俩个参数附加在设备字符串后面(使用了哪个参数就添加哪个参数):

  1. airtest run D:/test/moniqi_test.air --device Android://127.0.0.1:5037/127.0.0.1:62001?cap_method=JAVACAP^&^&ori_method=ADBORI --log E:/log_test

① 模拟器设备字符串的定义为:

  1. Android://<adbhost[localhost]>:<adbport[5037]>/模拟器端口号

其中,adbhostadb server所在主机的ip,默认是本机127.0.0.1adb port默认是5037

② 设备字符串后面跟了多个参数,需要用&&来连接,但是&这个字符需要转义才能够生效: Windows下改写成^&^&,MAC下改写成/&/&

2)在脚本编写模拟器的connect_device语句

如果不想在命令行中传入设备参数,我们也可以在脚本内编写connect_device语句来连接模拟器设备:

  1. # -*- encoding=utf8 -*-
  2. __author__ = "xiaoming"
  3. from airtest.core.api import *
  4. dev = connect_device("Android://127.0.0.1:5037/127.0.0.1:62001?cap_method=JAVACAP^&^&ori_method=ADBORI")
  5. auto_setup(__file__)

这样在命令行运行脚本时,就不用添加连接模拟器设备的参数了。

3)在纯.py脚本传入模拟器设备参数

如果我们使用纯.py脚本,在设备初始化时,也需要传入相应的模拟器设备参数:

  1. # -*- encoding=utf8 -*-
  2. __author__ = "xiaoming"
  3. from airtest.core.api import *
  4. from airtest.cli.parser import cli_setup
  5. if not cli_setup():
  6. auto_setup(__file__, logdir=True, devices=[
  7. "Android://127.0.0.1:5037/127.0.0.1:62001?cap_method=JAVACAP^&^&ori_method=ADBORI",
  8. ])