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

news2025/1/10 3:12:42

文章目录

      • 一、背景
      • 二、环境准备
      • 三、总结
      • 四、扩展
        • 4.1、WDA Client
        • 4.2、先使用WDA实现自动化
        • 4.3、代码示例:
        • 4.4、脱离macOS测试iOS App自动化,两个解决方案:
        • 4.5、第二种解决办法:pip install -U weditor
        • 4.6、下载安装Appium-Inspector:
        • 4.7下载安装nodejs
      • 问题1:appium-doctor --ios检查iOS运行环境
      • 问题2:appium启动服务
      • 问题3:capabilities配置问题,注意udid是真机设备id、webDriverAgentUrl是tidevice启动真机wda监听地址、automationName是iOS驱动xcuitest对比Android的就是uiautomator2
      • 问题4:日志分析
      • 扩展:软件环境概览

一、背景

给出这套解决方案的真相是因为大多数人都没有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)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1122991.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023 年 42 周 - 学习 倦怠期回顾

2023 年 42 周 - 学习 & 倦怠期回顾 本周属于反思怪的时间,1/4 的内容涉及到反思自己,剩下超过 2/3 的内容是对于学习方法加强的笔记 顺便重新复习了一下上周的笔记,然后发现,其实周算错了……截图的日历直接用周日算成一周…

【tg】 7 GroupInstanceCustomImpl

group GroupInstanceCustomImpl 核心GroupInstanceCustomInternal G:\CDN\P2P-DEV\tdesktop-offical\Telegram\ThirdParty\tgcalls\tgcalls\group\GroupInstanceCustomImpl.h 最核心是是GroupInstanceCustomInternal: private:std::shared_ptr<Threads> _threads;std::u…

python学习笔记:引用、浅拷贝和深拷贝(底层原理)

前言 在python中“一切皆对象”&#xff0c;包括整数&#xff08;int&#xff09;&#xff0c;小数&#xff08;float&#xff09;等 引用 Python解释器维护了一个内部的数据结构&#xff0c;称为命名空间或符号表&#xff0c;它将变量名与对象的内存地址关联起来。当您创建一…

【ArcGIS模型构建器】02:shp批量转kml/kmz

文章目录 一、加载实验数据二、设计模型构建器三、保存模型构建器 一、加载实验数据 打开ArcMap&#xff0c;加载专栏配套实验数据data02.rar中的&#xff0c;位于乡镇根目录文件夹内的15个乡镇矢量数据。 接下来跟我一步步实现用模型构建器批量转为kml。 二、设计模型构建器…

如何创建前端绘图和图表?

聚沙成塔每天进步一点点 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发…

外贸找客户软件:BotMaster 2023 Crack

具有多设备支持的全新 WhatsApp™ Business 批量发送器 最新9.0.2.1 稳定且工作。 测试日期&#xff1a;2023 年 10 月 9 日 所有功能工作正常。 图像发送问题固定 数字过滤器和组抓取器已修复。 目前稳定 现在使用 BotMaster 9.0.2.1 从 WhatsApp™ 发送交互式按钮 您现在可以…

设置host

macOS sudo nano /etc/hosts sudo nano /etc/hosts127.0.0.1 yourdomain.com 127.0.0.1 subdomain.yourdomain.com 将 yourdomain.com 替换为您要配置的域名&#xff0c;将 subdomain.yourdomain.com 替换为您要配置的子域名。确保 IP 地址为 127.0.0.1&#xff0c;这将指向…

C++对象模型(19)-- 函数语义学:成员函数

1、普通成员函数的调用 1.1 调用方式的转换 为了提高普通成员函数的调用效率&#xff0c;在C中&#xff0c;对普通成员函数的调用&#xff0c;会转换成对全局函数的调用。 假如有下面所示的成员函数&#xff1a; class Test { public:int m_i;int func(int a) {m_i a;retu…

划片机:半导体芯片是如何封装的?

半导体芯片的封装是指将芯片内部的电路通过引脚、导线、焊盘等连接起来&#xff0c;并保护芯片免受外部环境的影响&#xff0c;同时满足外部电路的连接需求。以下是半导体芯片封装的常见步骤&#xff1a; 1. 减薄&#xff1a;将晶圆研磨减薄&#xff0c;以便于后续的划片操作。…

2023京东双十一活动今晚20点开始?京东双十一时间安排和满减规则

2023京东双十一活动时间节点&#xff01; 京东双十一红包&#xff0c;同样是每天可以领取&#xff0c;10月23日开始&#xff0c;面额最高11111元。 京东app搜索【红包到手210】即可领取双11红包 (数字要带上) 2023年京东双11整体将围绕六个时期展开&#xff1a; 1、第一波&…

如何处理前端多语言支持?

聚沙成塔每天进步一点点 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发…

最成功的国产手机得到央视认可,自研系统走向国际挑战谷歌

随着美国对中国企业不断采取措施&#xff0c;中国手机企业都在努力自主创新&#xff0c;日前又一家国产手机自研操作系统被网友质疑&#xff0c;不过央视却肯定了这家企业在创新方面的优势&#xff0c;赞扬了它带动中国制造走向国际市场。 央视给予赞誉的这家企业就是小米&…

QSlider 类使用教程

文章目录 1、简介2 、公共类型3、属性4、functions4.1、访问属性相关 function4.2、公共槽4.3、Signal4.4、其他方法 5、设置样式 QT 官方文档参考地址&#xff1a;https://doc.qt.io/qt-5/qslider.html 1、简介 QSlider是垂直或水平滑块条控件&#xff0c;最常见的应用就是视…

摩尔信使MThings的报文管理功能

设备通信过程中&#xff0c;通道报文是关键调试信息。为了高效地辅助调试运维过程&#xff0c;摩尔信使MThings提供报文记录功能&#xff0c;支持丰富且友好的方法进行报文管理&#xff0c;包括&#xff1a;收发颜色标记、异常识别、通道过滤、支持Modbus全系列&#xff1b; 查…

springboot项目多数据源导致事务报错问题

springboot项目多数据源导致事务报错问题 序言报错日志报错原因解决办法序言 序言 之前有一篇讲了如何使用多数据源动态配置&#xff0c;这里遇到的一个问题和大家分享&#xff0c;在使用多数据源时&#xff0c;对数据进行更新和插入避免不了使用事务&#xff0c;使用多数据源…

推荐系统:从经典模型到深度学习,你需要掌握什么?

文章目录 &#x1f31f; 协同过滤&#xff1a;最经典的推荐模型&#xff0c;我们应该掌握什么&#xff1f;&#x1f31f; 深度学习革命&#xff1a;深度学习推荐模型发展的整体脉络是怎样的&#xff1f;&#x1f31f; TensorFlow入门和环境配置&#x1f31f; 模型特征、训练样本…

Delphi 编程实现拖动排序并输出到文档

介绍&#xff1a;实现拖动排序功能&#xff0c;并将排序后的内容输出到文档中。我们将使用 Delphi 的组件来创建一个界面&#xff0c;其中包括一个 Memo 控件用于输入内容&#xff0c;一个 ListBox 控件用于显示排序后的内容&#xff0c;并且提供按钮来触发排序和输出操作。 代…

万宾科技智能井盖传感器怎么使用?

时代在进步&#xff0c;科技在更新&#xff0c;人们身边的万事万物都在随着时代的脚步不断的前进。各种各样高科技技术在城市基础设施建设的过程中得到应用&#xff0c;很多智能产品不仅施工方便&#xff0c;而且可以向政府部门提供精准的数据&#xff0c;提高了相关管理人员的…

7.(vue3.x+vite)组件间通信方式之vuex

前端技术社区总目录(订阅之前请先查看该博客) 示例效果: Vuex 简介 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。每一个 Vuex 应用的核心就是 store(仓库)。“store” 基本上就是一个容器,它包含着你的应用中大部分的状态 ( state )。 (1)Vuex 的状态存储是…

居民小区电动汽车有序充电策略研究

摘 要&#xff1a;针对电动汽车在居民小区无序充电对电网系统产生严重隐患及充电间时过长问题&#xff0c;提出一种采用延迟充电的电动汽车有序充电控制策略&#xff0c;并在分析国内外电动汽车有序充电的研究现状后&#xff0c;设计了居民小区电动汽车有序充电策略的总体框架。…