前言

一直以来,iOS自动化的实现&执行都依赖 Mac 系统,其主要原因是因为需要通过 Xcodebuild 编译&安装 WDA (WebDriverAgent) 到 iOS 设备中,通过WDA实现对被测应用进行操作。而Windows系统无法运行Xcode工具,所以无法运行iOS自动化测试。

Windows上实现iOS APP自动化测试:tidevice + WDA + facebook-wda / appium - 测试开发小记 -

tidevice 简介

针对这种情况,阿里团队开源了一个内部使用的 iOS自动化工具 :

tidevice (https://github.com/alibaba/taobao-iphone-device) 让我们可以更方便、简单的脱离Mac的限制。

功能

该工具能够用于与iOS设备进行通信, 提供以下功能

  • 截图
  • 获取手机信息
  • ipa包的安装和卸载
  • 根据bundleID 启动和停止应用
  • 列出安装应用信息
  • 模拟Xcode运行XCTest,常用的如启动WebDriverAgent测试(此方法不依赖xcodebuild)
  • 获取指定应用性能(CPU,MEM,FPS)
  • 其他
  • 支持运行在Mac,Linux,Windows上

tidevice核心原理

usbmux通信协议:实现 Mac/Windows/Linux与 iOS设备服务间的通信

Mac端:usbmuxd 是苹果的一个服务,这个服务主要用于在USB协议上实现多路TCP连接,将USB通信抽象为TCP通信。苹果的iTunes、Xcode,都直接或间接地用到了这个服务。

Linux / Windows端:本身是没有 usbmux的,不过都有开源项目的实现,可以直接使用参考

Windows 另外依赖 AppleApplicationSupport和AppleMobileDeviceSupport 两个服务,安装Itunes 环境即可安装对应服务。

usbmux 本身是socket套接字,通过截获等手段,结合开源界的成果,用python 进行模拟,从而实现了当前工具已有的所有功能

tidevice安装

  • Python 3.6+
  • tidevice 安装

pip3 install -U "tidevice[openssl]" (推荐)

pip3 install -U tidevice

usbmuxd 安装 

PS:win下其实不用装。

tidevice 使用 #略

运行WDA

1.运行WDA(WebDriverAgent)之前首先需要将iOS设备安装好WDA应用。WDA安装需要在Mac电脑中打开xcode然后编译安装。具体参考官网实例。

2.打开命令窗口输入如下命令,注意修改端口号为8200,避免与WDA默认端口8100冲突。

tidevice wdaproxy -B com.facebook.WebDriverAgentRunner.xctrunner --port 8200

其中的包名通过tidevice applist找到WDA应用的包名。

运行之后,如果最后报WebDriverAgent start successfully则表示运行成功。

3.运行完成后在打开浏览器输入地址: http://127.0.0.1:8200/status查看返回内容,正常会返回一个json数据。

注意:目前已知的两个问题

  • 不支持运行企业证书签名的WDA
  • 未认证的数据线可能导致WDA连接中断,建议使用原装苹果数据线。

4.运行WDA后启动Appium服务即可开始执行iOS自动化测试。

Win环境使用appium运行注意事项

Win环境运行注意需要配置相关参数配置,另外需要安装好iTunes具体如下:

  • automationName:执行引擎,iOS设备需要设置为XCUITest
  • webDriverAgentUrl:iOS运行脚本中,需要配置 webDriverAgentUrl 给 appium driver ,才会不触发 appium 内置的用 xcode 启动 wda 这个流程。否则只要触发这个,appium就会找 xcode 。windows 没有 xcode ,自然跑不下去从而出现报错Error: The usbmuxd socket at '/var/run/usbmuxd' does not exist or is not accessible
  • usePrebuiltWDA:使用已经编译好的WDA这里填true
  • useXctestrunFile:使用Xctestrun文件启动WDA。由于此功能期望您已经构建了WDA项目,因此它既不会检查您是否具有必要的依赖关系来构建,WDA也不会尝试构建项目。默认为false。
  • skipLogCapture:跳过以开始捕获日志,默认为false。

PS:Windows不要忘记要安装iTunes应用。!!

运行iOS自动化

启动WDA服务,然后可以在Win使用Appium(暂没调研) 或 facebook-wda 来运行iOS自动化了。

facebook-wda需要安装:

pip3 install -U facebook-wda

官网说明及API介绍:

GitHub - openatx/facebook-wda: Facebook WebDriverAgent Python Client Library (not official)

简单实例:

wda.DEBUG=True
c=wda.USBClient()
s=c.session()
time.sleep(4)
s.app_activate("com.guokr.zaihang")
s.click(400,500)

参考网址:跨平台iOS自动化测试工具——tidevice | Sutune

Win 下成功 Appium+iOS 自动化 · TesterHome

脱离 Mac 搞 iOS 自动化,tidevice 工具教你轻松实现! · TesterHome