iOS自动化测试方案(三):WDA+iOS自动化测试解决方案

简介: 这篇文章是iOS自动化测试方案的第三部分,介绍了在没有MacOS系统条件下,如何使用WDA(WebDriverAgent)结合Python客户端库facebook-wda和tidevice工具,在Windows系统上实现iOS应用的自动化测试,包括环境准备、问题解决和扩展应用的详细步骤。

一、背景

给出这套解决方案的真相是因为大多数人都没有MacOS系统的条件,无法在MacOS端实现iphone手机app自动化测试,一是购买设备成本太大,二是因为条件所限(金钱),阻碍进行iOS移动应用的自动化测试进程;所以需要另辟蹊径找到iOS移动应用的自动化测试解决方案,皇天不负有心人,终于让题主找到了,当然这也是现有的解决方案:python(facebook-wda)+webdriveragent。

二、环境准备

1、python版本3.6及以上,使用anaconda环境管理器,conda activate 进入base虚拟环境;

conda create -n iOSApp python==3.7.5
在这里插入图片描述
$ conda activate iOSApp 激活虚拟环境

2、tidevice安装

一种常见的解决方案是使用xcodebuild来启动WebDriverAgent,而xcode需要Mac系统,也就是必须在MAC上进行iOS自动化测试。
tidevice 是阿里开源的一个基于Python的iOS自动化工具,通过逆向iOS通信协议,模拟xcodebuild与手机进行通信,向手机发送特定的指令,来启动WDA,从而可以脱离Mac电脑,能够在Linux、Windows上运行iOS自动化。tidevice基于python实现了libimobiledevice中的功能。
tidevice通过usbmuxd与手机通信来启动WDA,通过建立一个TCP连接到usbmuxd的/var/run/usbmuxd TCP端口,然后usbmuxd将请求发送到USB连接的iPhone上。上面提到的libimobiledevice就是一个跨平台的用于与iOS设备进行通信的库。

pip install -U "tidevice[openssl]" ,出现successfully built 表示安装成功

在这里插入图片描述
检查tidevice版本号:tidevice version或tidevice -v
在这里插入图片描述

3、连接iphone设备:tidevice list 或tidevice list --json
在这里插入图片描述

4、应用管理常用命令tidevice

安装应用: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
查看运行中的应用:tidevice ps 或tidevice ps —json output as json

# 运行XCTEST
$ tidevice xctest -B com.facebook.wda.WebDriverAgent.Runner
# 运行XCTEST,修改监听端口为8200, 并显示调试日志
$ tidevice xctest -B com.facebook.wda.WebDriverAgent.Runner -e USB_PORT:8200 --debug

# 转发请求到手机,类似于iproxy
$ tidevice relay 8100 8100
# 转发并把传输的内容用hexdump的方法print出来
$ tidevice relay -x 8100 8100


# 运行 XCTest 并在PC上监听8200端口转发到手机8100服务
# wdaproxy这个命令会同时调用xctest和relay,另外当wda退出时,会自动重新启动xctest
# 不支持运行企业证书签名的WDA
$ tidevice wdaproxy -B com.facebook.wda.WebDriverAgent.Runner --port 8200

# 查看设备信息
$ tidevice info

# 查看设备电源信息
$ tidevice info --domain com.apple.mobile.battery --json

# 重启
$ tidevice reboot

# 截图
$ tidevice screenshot screenshot.jpg

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

# 输出日志 same as idevicesyslog
$ tidevice syslog

# 你查看性能
$ tidevice perf -B appname

tips:tidevice ps异常:Developer Mode is not opened, to enable Developer Mode goto Settings -> Privacy & Security -> Developer Mode

iphone 需要开启开发者模式: 设置–隐私和安全–安全性(开发者模式)–默认关闭,打开会重新手机
在这里插入图片描述
开启之后:tidevice ps
在这里插入图片描述

三、总结

上面的步骤已经基本可以实现tidevice命令行操作app应用了,但是它还不能实现自动化,自动化工具还需要appium的结合;这里涉及一个问题就是跨平台,既然咱们只想在win系统实现iOS应用的自动化测试,那么免不了需要代理,怎么代理呢?webdriveragent就是安装在iOS真机设备上的应用,需要它转发到win系统,并且通过python脚本去执行iOS应用。

四、扩展

WDAClient:WDA的客户端,测试库facebook-wda 就是 WDA 的 Python 客户端库,通过HTTP协议(Mobile JSON Wire Protocol)与WebDriverAgent进行通信。
WebDriverAgentRunner:运行在手机上的WDA server,默认监听端口为8100,主要功能包括①接收WDAClient的请求并将操作命令发送给XCTest.framework。②将响应发送给WDA Client

4.1、WDA Client

WDA Client是基于WebDriverAgent实现的WDA的客户端。
我们在 iOS 设备上启动了 WDA 的服务端。为了运行 Mac OS 上的脚本,我们需要在 Mac OS 上安装 WDA 客户端。
facebook-wda 就是 WDA 的 Python 客户端库,通过直接构造HTTP请求直接跟WebDriverAgent通信。

# 安装 WDA python 客户端
pip3 install --pre facebook-wda
4.2、先使用WDA实现自动化

WebDriverAgent是Facebook开发的一个iOS自动化测试工具;这个应用需要本地构建直接安装到iOS真机设备,即使外面流传的ipa包都无法安装,因为它需要重新签名才行。WDA在Client创建了一个Server,在手机端安装了一个叫作WebDriverAgentRunner 的一个应用;这个应用会接收来自 Server 的指令,并连接底层的XCTest.framwork,让 XCTest.framwork 调用苹果API来操作手机进行自动化

~#: tidevice  list  #  得到设备Udid
3a174cf4dd652dab19a9adb40470959db5325b70
~#: tideivce applist # 得到app名称
com.bytedance.ee.lark
4.3、代码示例:
import wda

c = wda.Client('http://127.0.0.1:8100')
c.session().app_activate("com.byd.BYDi")
c(name="我的").click()
c(name="每日签到").click()
4.4、脱离macOS测试iOS App自动化,两个解决方案:

1、准备macOS系统的电脑设备,直连iOS测试app
2、macOS系统可以使用虚拟机,只要支持usb接口
3、基于第二个方案,使用macOS虚拟机xcode构建WDA应用安装到iOS真机,然后使用tidevice+wda(真机设备启动的服务端)+python(facebook-wda作为客户端)完成App自动化测试解决方案
在这里插入图片描述

$ tidevice -u [设备 udid] wdaproxy -B [wda 的 bundle Id] --port 8100 # 运行 XCTest 并在PC上监听8100端口
设备udid:tidevice list 获取
[wda 的 bundle Id] 是编译的wda应用的标识,意思是在iphone设备代理wda转发到pc上8100端口监听,通过tidevice applist找到wda的bundle Id
$ tidevice -u 3a174cf4dd652dab19a9adb40470959db5325b70 wdaproxy -B com.facebook.WebDriverAgentRunner314156.xctrunner --port 8100 # 运行 XCTest 并在PC上监听8100端口
在这里插入图片描述

看到最后:WebDriverAgent start successfully
在这里插入图片描述

本地访问:http//127.0.0.1:8100/status;
http://127.0.0.1:8100/inspector已经被appium兼并,所以可以通过appium-desktop来获取iOS真机应用元素
tidevice xctest -B $BUNDLE_ID …通过包名启动WebDriverAgent(单台)

4.5、第二种解决办法:pip install -U weditor

安装最新的版本,容易出错,指定0.6.3版本
在这里插入图片描述

一般人都喜欢钻牛角尖,认为自己一定能解决,殊不知网络一片解决不了原版本的问题,不得已,只能降低版本

pip install weditor==0.6.3
在这里插入图片描述

python -m weditor启动
在这里插入图片描述

如果不能访问,需要转发端口:tidevice relay 8300 8100
有些iphone手机通过手机的IP和端口号还不能访问,此时需要将手机的端口转发到mac上;iproxy 8100 8100 # iproxy 8300 8100;所以在win系统是不存在这个操作

4.6、下载安装Appium-Inspector:

npm install app-inspector -g
下载地址:https://github.com/appium/appium-inspector/releases/download/v2023.8.1/Appium-Inspector-windows-2023.8.1.exe
在这里插入图片描述

启动appium-inspector
在这里插入图片描述

4.7、下载安装nodejs
npm -version
npm install -g appium --registry=https://registry.npm.taobao.org
npm install --location=global appium  --registry=https://registry.npm.taobao.org --drivers=xcuitest,uiautomator2
npm install -g appium-doctor

在这里插入图片描述

安装appium之后,需要python本机环境安装wda

pip3 install -U facebook-wda
# facebook-wda 就是 WDA 的 Python 客户端库,通过直接构造HTTP请求直接跟WebDriverAgent通信

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

问题1:appium-doctor --ios检查iOS运行环境

在这里插入图片描述

修复建议:因为咱们的[iOS]自动化测试解决方案是win系统下python+appium+wda+tidevice,所以need需要的xcode、Carthage都不需要,唯独需要nodejs安装之后npm安装appium即可;下面的那些ios-deploy都是mac需要的吧
在这里插入图片描述

问题2:appium启动服务

突然发现咱们的是iOS系统,没有XCuiTest插件,使用appium plugin命令 install安装,

问题: Could not find a driver for automationName ‘XCUITest’ and platformName ‘ios’. Have you installed a driver that supports those capabilities? Run ‘appium driver list --installed’ to see. (Lower-level error: Could not find installed driver to support given caps)
说的是环境没有找到automationName是XCUITest
appium driver list --install
在这里插入图片描述

原因是先安装了appium driver install xcuitest然后再appium driver install uiautomator2结果把前面的覆盖卸载了,所以只要安装前者,它会有两个驱动插件
在这里插入图片描述

结果如下
在这里插入图片描述

问题3:capabilities配置问题,注意udid是真机设备id、webDriverAgentUrl是tidevice启动真机wda监听地址、automationName是iOS驱动xcuitest对比Android的就是uiautomator2

capabilities={
    "platformName": "ios",
    "platformVersion": "16.6",
    "deviceName": "iPhone 8P",
    "udid": "3a174cf4dd652dab19a9adb40470959db5325b70",
    "bundleId": "com.byd.BYDi",
    "webDriverAgentUrl": "http://127.0.0.1:8100",
    "noReset": True,
    "usePrebuiltWDA": False,
    "useXctestrunFile": False,
    "skipLogCapture": True,
    "automationName": "XCuiTest"
}

XCUITest是苹果开发的一个做IOS自动化测试的框架-

问题4:日志分析

1、appium启动成功,有监听服务+端口、有正确的驱动
2、python或其他配置保持一致的capabilities属性
3、npm安装appium有对应的wda代理服务,有些博客说要自己下载appium/webdriveragent去覆盖appium安装的wda;appium是把WebDriverAgentRunner给集成进去了,因此实现了appium的跨平台能力
4、这是tidevice启动真机安装的wda代理服务器,可/status访问得到基本设备信息
5、python脚本通过配置wda代理驱动被测应用,创建下面可执行的sessionId
在这里插入图片描述

扩展:软件环境概览

1、appnium环境:The prerequisites for Appium:

  • Installation of Nodejs 10+ and Node Package Manager (NPM)
  • Appium
  • Appium Doctor
  • Java JDK +8
  • Maven
  • IntelliJ as an IDE, which is the recommended IDE, but you can use any editor or IDE that you want

2、iOS环境 The iOS requirements to use Appium:

  • Mac OS Operating System version 10.13 or higher
  • Homebrew installed
  • Xcode installed (+10 on your machine)
  • Carthage
  • Ios-deploy
  • ideviceinstaller
  • Apple developer account
  • Apple developer tools (including iPhone simulator SDK and command-line tools)
相关文章
|
27天前
|
测试技术 Linux 虚拟化
iOS自动化测试方案(五):保姆级VMware虚拟机安装MacOS
详细的VMware虚拟机安装macOS Big Sur的保姆级教程,包括下载VMware和macOS镜像、图解安装步骤和遇到问题时的解决方案,旨在帮助读者顺利搭建macOS虚拟机环境。
43 3
iOS自动化测试方案(五):保姆级VMware虚拟机安装MacOS
|
22天前
|
前端开发 开发工具 Android开发
探索安卓与iOS应用开发:跨平台解决方案的崛起
【8月更文挑战第27天】在移动设备日益普及的今天,安卓和iOS系统占据了市场的主导地位。开发者们面临着一个重要问题:是选择专注于单一平台,还是寻找一种能够同时覆盖两大系统的解决方案?本文将探讨跨平台开发工具的优势,分析它们如何改变了移动应用的开发格局,并分享一些实用的开发技巧。无论你是新手还是资深开发者,这篇文章都将为你提供有价值的见解和建议。
|
27天前
|
测试技术 数据安全/隐私保护 iOS开发
iOS自动化测试方案(四):保姆级搭建iOS自动化开发环境
iOS自动化测试方案的第四部分,涵盖了基础环境准备、iPhone虚拟机设置、MacOS虚拟机与iPhone真机的连接,以及扩展问题和代码示例,确保读者能够顺利完成环境搭建并进行iOS自动化测试。
56 0
iOS自动化测试方案(四):保姆级搭建iOS自动化开发环境
|
18天前
|
测试技术 Swift iOS开发
探索iOS自动化测试:使用Swift编写UI测试
【8月更文挑战第31天】在软件开发的海洋中,自动化测试是保证船只不偏离航线的灯塔。本文将带领读者启航,深入探索iOS应用的自动化UI测试。我们将通过Swift语言,点亮代码的灯塔,照亮测试的道路。文章不仅会展示如何搭建测试环境,还会提供实用的代码示例,让理论知识在实践中生根发芽。无论你是新手还是有经验的开发者,这篇文章都将是你技能提升之旅的宝贵指南。
|
25天前
|
前端开发 JavaScript Android开发
安卓与iOS开发中的跨平台解决方案
【8月更文挑战第24天】在移动应用开发领域,安卓和iOS两大平台占据了主导地位。然而,为这两个平台分别开发和维护应用会带来额外的时间和成本。本文将探讨跨平台开发的概念、优势以及流行的跨平台框架,如React Native和Flutter,并分析它们如何解决多平台开发的挑战。
|
12天前
|
运维 Ubuntu Devops
自动化运维工具的魅力:Ansible入门
【9月更文挑战第5天】在快速变化的IT世界里,自动化运维不再是可选项,而是必需品。Ansible,一款简单却强大的自动化工具,正成为众多DevOps工程师的首选。本文将带你了解Ansible的基本概念、安装步骤以及如何编写简单的Playbook,从而开启你的自动化之旅。
58 35
|
9天前
|
存储 弹性计算 运维
自动化监控和响应ECS系统事件
阿里云提供的ECS系统事件用于记录云资源信息,如实例启停、到期通知等。为实现自动化运维,如故障处理与动态调度,可使用云助手插件`ecs-tool-event`。该插件定时获取并转化ECS事件为日志存储,便于监控与响应,无需额外开发,适用于大规模集群管理。详情及示例可见链接文档。
|
2天前
|
机器学习/深度学习 运维 安全
构建高效运维体系:从自动化到智能化的演进之路
在数字化转型的浪潮中,运维管理作为信息技术基础设施的重要支柱,正经历着从传统手工操作向自动化、智能化的深刻变革。本文将探讨如何通过引入自动化工具和平台,实现运维流程的标准化与效率提升;进而利用大数据分析和人工智能技术,迈向预测性维护和智能决策支持的高级阶段。通过案例分析,揭示成功转型的关键因素,为运维专业人士提供一套可借鉴的升级路径。
|
5天前
|
机器学习/深度学习 运维 监控
构建高效运维体系:从自动化到智能化的演进
在当今信息技术飞速发展的时代,运维领域正经历着从传统手动操作向高度自动化和智能化转变。本文旨在探讨如何通过集成自动化工具、实施持续集成与持续部署(CI/CD)、采用容器化技术和探索AIOps实践,构建一个高效、可靠的运维体系。我们将分析这些技术如何相互配合,提升运维效率,降低系统故障率,并实现快速响应市场变化的能力。通过案例分析和最佳实践的分享,本文将为IT专业人员提供一套实用的指南,帮助他们在数字化转型的浪潮中,保持运维工作的前瞻性和竞争力。
|
6天前
|
机器学习/深度学习 数据采集 人工智能
智能化运维的探索之旅:从自动化到人工智能
在数字化浪潮中,运维领域正经历一场革命。本文将带你领略从传统手动操作到自动化脚本,再到集成人工智能的智能运维平台的演变之路。我们将探讨如何通过技术创新提升效率、降低成本并增强系统的可靠性和安全性。文章不仅分享技术演进的故事,还提供了实现智能化运维的实践策略和未来趋势的展望。