专栏首页QA一隅跨平台iOS自动化测试工具——tidevice

跨平台iOS自动化测试工具——tidevice

前言

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

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/LinuxiOS设备服务间的通信

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

Linux / Windows端:本身是没有 usbmux的,不过都有开源项目的实现,可以直接使用参考 Windows 另外依赖 AppleApplicationSupportAppleMobileDeviceSupport 两个服务,安装Itunes 环境即可安装对应服务。

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

tidevice安装

  • Python 3.6+
  • tidevice 安装
pip3 install -U "tidevice[openssl]” (推荐)
pip3 install -U tidevice (缺少设备配对功能)

usbmuxd 安装

  • Mac 自带:/var/run/usbmux
  • Linux/Windows: 参考官方建议的 https://github.com/alibaba/taobao-iphone-device/issues/7

tidevice 使用

查看版本号

$ tidevice version
0.1.0

列出连接设备

$ tidevice list
List of apple devices attached
00008030-001A35E40212345678 codeskyblue的iPhoneSE

$ tidevice list --json
[
    {
        "udid": "00008030-001A35E40212345678",
        "name": "codeskyblue的iPhoneSE"
    }
]

应用管理

# 安装应用
$ tidevice install example.ipa

# 指定设备安装
$ tidevice --udid $UDID install https://example.org/example.ipa

# 卸载应用
$ tidevice uninstall com.example.demo

# 启动应用
$ tidevice launch com.example.demo

# 停止应用
$ tidevice kill com.example.demo

# 查看已安装应用
$ tidevice applist
Run XCTest
请先确保手机上已经安装有WebDriverAgent应用

设备管理

# 重启
$ tidevice reboot

# 截图
$ tidevice screenshot screenshot.jpg

# 性能采集 (TODO)
# $ tidevice perf -o fps,mem,cpu -B com.example.demo

# 输出日志 same as idevicesyslog
$ tidevice syslog

运行WDA

  1. 运行WAD(WebDriverAgent)之前首先需要将iOS设备安装好WAD应用,具体可以参考 Appium+Mac环境搭建 安装好之后使用命令查看WDA名称:
atx:~ atx$ tidevice applist
com.fish.stream Stream 1.0.6
com.tencent.mqqsecure 腾讯手机管家 8.9.5
com.sina.weibo 微博 11.4.0
com.dji.mimo DJI Mimo 1.5.16
com.tencent.QQMusic QQ音乐 10.11.1
com.facebookWebDriverAgentRunner.xctrunner WebDriverAgentRunner-Runner 1.0
  1. 打开命令窗口输入如下命令,注意修改端口号为8200,避免与WDA默认端口8100冲突。
atx:~ atx$ tidevice wdaproxy -B com.facebookWebDriverAgentRunner.xctrunner --port 8200
[D 210417 10:04:52 _wdaproxy:116] [6dd5e55bf4204cd5ad8042dc4exxxxxxxxx] launch WDA
[I 210417 10:04:53 _device:990] BundleID: com.facebookWebDriverAgentRunner.xctrunner
[I 210417 10:04:53 _device:992] DeviceIdentifier: 6dd5e55bf4204cd5ad8042dxxxxxxx
[I 210417 10:04:53 _device:834] SignIdentity: 'Apple Development: 技术部门 xx (WKQZHDVG49)'
[I 210417 10:04:53 _device:840] CFBundleExecutable: WebDriverAgentRunner-Runner
[I 210417 10:04:53 _device:871] AppContainer: /private/var/mobile/Containers/Data/Application/A2492414-BF14-4E2F-9130-5C50AB8E503E
[I 210417 10:04:54 _device:911] Launch 'com.facebookWebDriverAgentRunner.xctrunner' pid: 838
[I 210417 10:04:54 _device:1086] ProductVersion: 12.1.2
[I 210417 10:04:55 _device:1034] Start execute test plan with IDE version: 29
[I 210417 10:04:56 _device:947] WebDriverAgent start successfully
  1. 运行完成后在打开浏览器输入地址: http://127.0.0.1:8200/status查看返回内容,正常返回如下内容:
{
  "value" : {
    "message" : "WebDriverAgent is ready to accept commands",
    "state" : "success",
    "os" : {
      "testmanagerdVersion" : 26,
      "name" : "iOS",
      "sdkVersion" : "13.0",
      "version" : "12.1.2"
    },
    "ios" : {
      "ip" : "172.28.xxx.xxx"
    },
    "ready" : true,
    "build" : {
      "time" : "Apr 11 2021 10:54:49",
      "productBundleIdentifier" : "com.facebook.WebDriverAgentRunner"
    }
  },
  "sessionId" : null
}

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

  • 不支持运行企业证书签名的WDA
  • 未认证的数据线可能导致WDA连接中断,建议使用原装苹果数据线。
  1. 运行WDA后启动Appium服务即可开始执行iOS自动化测试。

Win环境运行注意事项

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

  • automationName:执行引擎,iOS设备需要设置为XCUITest
  • webDriverAgentUrliOS运行脚本中,需要配置 webDriverAgentUrlappium driver ,才会不触发 appium 内置的用 xcode 启动 wda 这个流程。否则只要触发这个,appium就会找 xcodewindows 没有 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
{
  "udid": "6dd5e55bf4204cd5ad8042dc4ecb2xxxxxx",
 "automationName": "XCUITest",
  "deviceName": "iphone8",
  "platformName": "iOS",
  "platforVersion": "12.1.2",
  "bundleId": "com.hxxxxx",
  "webDriverAgentUrl": "http://localhost:8200",
 "usePrebuiltWDA": "true",
  "useXctestrunFile": "false",
"skipLogCapture": "true",
"automationName": "XCUITest"
}

本文分享自微信公众号 - QA一隅(sutune2020),作者:Sutune

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2021-05-17

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 测试开发:推荐一款阿里最新 Python 自动化开源工具!

    如果之前做过iOS自动化的同学相信都知道,一直以来,iOS自动化的实现&执行都必须依赖 Mac 系统,其主要原因是因为需要通过xcodebuild 编译&安装W...

    测试开发技术
  • Appium系列(二十一)操作IOS设备利器——tidevice

    Appium自动化(八)通过脚本自动化获取设备deviceName和platformVersion

    雷子
  • Appium系列(二十五)引入stf 设备管理平台

    Appium自动化(八)通过脚本自动化获取设备deviceName和platformVersion

    雷子
  • Appium系列(二十二)基于tidevice封装IOS的adb命令

    Appium自动化(八)通过脚本自动化获取设备deviceName和platformVersion

    雷子
  • 使用WEditor开发APP自动化测试脚本

    WEditor是基于python的查看APP元素的工具,能够提供辅助编写脚本,定位元素,调试代码等功能。

    zx钟
  • Appium系列(二十五)封装操作stf的方法

    Appium自动化(八)通过脚本自动化获取设备deviceName和platformVersion

    雷子
  • Appium系列(二十四)对于现有的代码做个‘小手术’

    Appium自动化(八)通过脚本自动化获取设备deviceName和platformVersion

    雷子
  • Appium系列(二十三)改造框架代码适配IOS自动化

    Appium自动化(八)通过脚本自动化获取设备deviceName和platformVersion

    雷子
  • iOS真机安装WebDriverAgent图文详解

    在做iOS自动化测试的时候,一般都需要确保手机上已经安装有WebDriverAgent应用,这个WDA应用可以是Airtest修改版、Appium修改版也可以是...

    岛哥的质量效能笔记
  • 一分钟教你Android、iOS如何实现自动化截长图功能,超实用!

    在移动端自动化测试过程中经常会遇到需要截长图的场景,比如大促活动的H5页面、动态信息流页面等,但是目前在网上检索只能搜到关于截长图的软件推荐,没有讲关于如何通过...

    岛哥的质量效能笔记
  • Airtest跨平台的UI自动化测试框架(一)

    注释:软件部署成功之后,连接设备之后,设备端会生成两个插件,Yosemite和PocoService。

    用户5521279
  • Airtest跨平台的UI自动化测试框架(二)

    Configparser具体操作方法 第一步,新建一个ini文件,例如config.ini,然后编辑session,key,value字段。

    用户5521279
  • Gallio 自动化测试平台

    Gallio是MbUnit的作者组织开发的一个开源项目,非常值得从事测试开发的同学们的注意。 根据Gallio网站的描述:Gallio自动化平台是一个开放的,可...

    张善友
  • 自动化测试平台实战

    大家好,我是你的课程老师Fin,欢迎来到我的专栏《自动化测试平台实战39讲》,很高兴能在这里和你聊聊自动化测试平台。

    测试开发社区
  • 自动化测试平台TestDog-V1

    最近工作不是很饱和,为了充实自己于是有了搭建自动化平台的想法,希望把公司内部所有API、性能、功能自动化都统一起来管理,目前第一版主体功能基本已完成,特此记录下...

    wencheng
  • DevOps之自动化测试平台

    oss软件整体采用前后端分离的模式,前端采用JQuery自研组件,包含常用web组件。后端采用spring boot + spring cloud + cons...

    用户7533190
  • API测试平台,全程自动化测试

    API自动化测试平台可以对相关业务领域的API按照一定的业务逻辑进行编排然后进行自动化测试,可以完成非常复杂的API测试场景。RestCloud API自动化测...

    用户8905905
  • 测试思考拾叶集测试万能公式自动化测试自动化测试分层自动化测试框架工具平台数据准备服务Bug

    须理清“SUT的功能”,“SUT的所有输入”,“每一个输入的取值范围”,“SUT的所有输出”,“根据功能推出每一个输出的预期值”。

    一个会写诗的程序员
  • 前沿测试平台之GUI自动化测试

    GUI 测试的自动化技术可能是测试人员熟悉的,也是发展时间最长、应用最广的自动化测试技术。它的核心思想是,基于页面元素识别技术,对页面元素进行自...

    muntainyang

扫码关注云+社区

领取腾讯云代金券