Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地

article/2025/8/21 16:14:07

一 . 前言

由于IOS系统比Android系统相对封闭,所以进行IOS自动化测试也是相对复杂,不过大家不用担心,小编已经帮你们踩了大部分坑,网上大部分文章都是CV过来的,没有真正的从0到1落地,我们需要具备开源精神,只为让更多的小伙伴们少走弯路,欢迎大家在留言区评论交流!

二 . 环境依赖

*mac
*xcode
*python
*pycharm
*appium
*pytest
*jdk1.8
*allure
*git
*node
*jenkins
*npm or cnpm
*ios-deploy
*brew
*libimobiledvice
*carthage
*ios phone
*apple id
*webdriveragent

三 . 环境配置

1. 安装xcode

方式一:

如果已经升级至最新macOS系统,可以直接通过App Store安装最新版本的Xcode

方式二:

如果不想升级最新macOS系统,可以使用离线包的形式安装,安装地址:Xcode 版本(官方)

2. 安装python

小编这边采用的是python3.9,需要使用其他版本也可以,建议3.6+,安装地址:python3.9(官方)

3. 安装pycharm

下载社区版本免费,一般满足我们日常使用,安装地址:pycharm(官方)

4. 安装appium

小编这边采用的是appium 1.17.1,下载 Appium-mac-1.17.1.dmg 包即可, 安装地址:github appium 1.17.1(官方)

4.1 下载appium命令版,需要先安装npm,在文章后面有介绍

版本:1.17.1
终端:sudo npm install --unsafe-perm=true --allow-root -g appium@1.17.1

4.2 配置appium GUI版本

版本:1.17.1
参数:{
“bundleId”: “被测应用”,
“platformName”: “iOS”,
“platformVersion”: “15.2”,
“deviceName”: “设备名称”,
“automationName”: “XCUITest”,
“udid”: “可以使用xcode查询”
}

5. 安装pytest

打开已安装的Pycharm左下角,在Terminal打开当面目录下的命令行窗口,输入命令:

pip install pytest

6. 安装jdk1.8

6.1 使用allure报告或Android SDK必须依赖Java环境,下载dmg包进行安装即可,安装地址: oracle jdk1.8(官方)
在这里插入图片描述

6.2. 配置JDK环境变量

6.2.1 如果此前建过.bash_profile隐藏配置文件,直接在终端输入$ open -e .bash_profile打开文件即可,如果没有则输入下方命令

$ touch .bash_profile

6.2.2 输入下方命令打开此文件

$ open -e .bash_profile

6.2.3 打开.bash_profile文件输入环境配置参数,将下方参数放入其中,并保存(如果用的是vi打开的按esc 输入:wq退出如果是文本直接command + S)退出即可,JAVA_HOME是JDK安装路径,然后保存

JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk-11.jdk/Contents/Home
PATH=$JAVA_HOME/bin:$PATH:.
CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar:.
export JAVA_HOME
export PATH
export CLASSPATH

6.2.4 输入以下命令使配置文件生效

$ source .bash_profile

6.2.5 最后检查下环境变量是否配置成功

$ echo $JAVA_HOME

在这里插入图片描述
6.2.6 查询JDK版本信息

$ java -version

在这里插入图片描述
7. 安装allure

7.1 allure官网

	http://allure.qatools.ru/

7.2 allure下载地址,小编版本使用的是2.19.0

https://repo.maven.apache.org/maven2/io/qameta/allure/allure-commandline/2.19.0/

7.3 allure运行原理

allure属于第三方工具,展现更好看的测试报告,allure服务兼容pytest生成allure能识别的json文件,类似于 Apache ECharts你负责提供 ECharts能识别的json数据, ECharts负责展示不同的可视化图表

7.4 allure使用

7.4.1 下载zip包,默认在mac /users/用户/Downloads,然后解压到任意目录

7.4.2 配置环境变量,打开终端

$ open -e .bash_profile

添加此内容,和上面配置JDK环境变量一样

#allure 2.19.0
export PATH=/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin
export PATH=${PATH}:/Users/用户/allure-2.19.0/bin

PATH更换自己的,然后保存退出即可

7.4.3 验证allure环境变量是否安装成功

$ allure --version

在这里插入图片描述

7.4.4 结合pytest生成json测试文件

7.4.4.1 安装三方库

pip install allure-pytest

7.4.4.2 生成json测试文件,在pytest.ini文件中配置

[pytest]
addopts = -vs --alluredir ./temp

会自动生成json文件
在这里插入图片描述

在主函数中添加产生报告的代码 ,注意:路径应该与json测试文件路径保持一致

if __name__ == '__main__':pytest.main(["-vs", "test_case/test_all.py", '--clean-alluredir', '--alluredir=./temp'])os.system("allure generate ./temp -o ./report --clean")

打开自动生成的report目录下index.html即可
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

8. 安装git

方式一:

一般Xcode安装好后不需要再单独安装Git,Xcode自带git

方式二:

可以先安装后面的brew再安装git,终端输入该命令即可

brew install git

验证git是否安装成功,终端输入该命令即可

git --version

在这里插入图片描述

9. 安装node

说明:安装就有npm命令了,可以使用npm -v 查询是否安装成功,node -v 验证node.js版本
地址: node.js(官方)
版本:12.15.0

10. 安装jenkins

使用brew安装可能会存在更新的问题,小编这边使用包安装方式
安装地址:jenkins(官方)
在这里插入图片描述在这里插入图片描述

11. 安装npm or cnpm

说明:中国版的npm,速度更快
版本:5.2.0
终端:npm install -g cnpm --registry=https://registry.npm.taobao.org
提示:added 845 packages from 976 contributors in 11.97s,表示安装成功

12. 安装ios-deploy

说明:用于转发xcode的ip地址,对于一些国外的ios我们需要转发端口
终端:cnpm install -g ios-deploy

提示:** BUILD SUCCEEDED **表示安装成功

13. 安装brew

说明:使用终端命令brew -v去查看电脑是否已经安装,一般mac会自带,如果没有自行安装
版本:1.9.1
终端:ruby <(curl -fsSKL raw.github.com/mxcl/homebrew/go)

14. 安装libimobiledvice

说明:真机调试,检查是否连接设备,类似于安卓adb
终端:brew install --HEAD libimobiledevice

15. 安装carthage

说明:webdiverAgent需要
终端:brew install carthage

16. 注册apple id

说明:app store下载xcode时会跳出登录弹框
使用公司公共账号也可以,后续该账号需要加入公司开发者团队,一个团队可以加100个开发者账号
注册地址:注册apple id(官方)

17. 安装webdriveragent

原理:appium->WebDriverAgent->XCUITest
iOS 9 之前一直以 instruments 下的 UIAutomation 为驱动底层技术(弊端由于 instruments 的限制,单台 mac 只能对应单台设备);
iOS 9.3 时代推出 XCUITest 工具,用以替代 UIAutomation;
iOS 10 时代苹果直接废弃了 UIAutomation,Facebook 推出 WebDriverAgent(实现的 server 能够支持单台 mac 对应多个设备);
Appium 在 iOS 9.3 后全面采用 WebDriverAgent 的方案;
在这里插入图片描述
facebook下载地址:https://github.com/facebookarchive/WebDriverAgent
WebDriverAgent2年前facebook已不在维护!!!本人使用appium分支
appium下载地址:https://github.com/appium/WebDriverAgent
下载完成后终端进入该目录(你桌面WebDriverAgent项目的地址):cd /Users/用户名/Desktop/WebDriverAgent-master
终端:./Scripts/bootstrap.sh
最后使用xcode打开WebDriverAgent项目的WebDriverAgent.xcodeproj文件进行配置

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述配置完成之后,真机连接mac,使用command+u运行,ios上会自动安装一个runner程序,这是我们需要去手机设置描述文件信任该程序,运行成功后xcode控制台打印已下信息表示成功
在这里插入图片描述

18. 使用脚本获取driver对象

18.1 添加依赖 requirements.txt

allure_python_commons==2.8.19
Appium_Python_Client==0.46
HTMLTestRunner==0.8.0
pytest==6.2.5
selenium==3.141.0

18.2 恭喜你,到最后一步了,一段简单的代码,只是为了测试IOS自动化测试环境是否搭建成功

import time
from appium import webdriver
from tools.LoggerUtil import LoggerUtillogger = LoggerUtil()class InitDevices(object):driver: webdriver = None@classmethoddef start(cls, port: str, ip: str = '127.0.0.1', **kwargs):caps = {'bundleId': '填写你需要测试的app bundleId ','platformName': 'iOS','platformVersion': '14.4','deviceName': 'iPhone','automationName': 'XCUITest','udid': '00008020-001434C42232002E','newCommandTimeout': '21600'}if kwargs:for k, v in kwargs.items():caps[k] = vlogger.info("{} 我是主函数的驱动参数".format(caps))cls.driver = webdriver.Remote(f"http://{ip}:{port}/wd/hub", caps)cls.driver.implicitly_wait(10)logger.info("---连接设备成功---")logger.info("{} 我是主函数的driver".format(cls.driver))return cls.driverelse:logger.info("{} 我是主函数的驱动参数".format(caps))cls.driver = webdriver.Remote(f"http://{ip}:{port}/wd/hub", caps)cls.driver.implicitly_wait(10)logger.info("---连接设备成功---")logger.info("{} 我是主函数的driver".format(cls.driver))return cls.driver@classmethoddef quit(cls):"""关闭driver对象:return:"""cls.driver.quit()if __name__ == '__main__':comm = InitDevices.start('4723', noReset=True)time.sleep(1)comm.quit()

注意:连接设备后一定要quit()关闭连接,不然下次连接会出现端口占用的情况,本地运行不报错,控制台返回driver对象即成功了!

在这里插入图片描述


http://chatgpt.dhexx.cn/article/3jXYMIVE.shtml

相关文章

iOS完整学习路线图

今晚特地花时间整理出了iOS的完整学习路线图&#xff0c;希望对大家有帮助

iOS 自动化——技术方案、环境配置

移动端的自动化测试&#xff0c;最常见的是 Android 自动化测试&#xff0c;我个人觉得 Android 的测试优先级会更高&#xff0c;也更开放&#xff0c;更容易测试&#xff1b;而 iOS 相较于 Android 要安全稳定的多&#xff0c;但也是一个必须测试的方向&#xff0c;这个系列文…

Appium + IOS 自动化环境搭建教程(实践+总结+踩坑)

文章目录 前言IOS 自动化相关框架介绍自动化测试类工具内测发布工具Appium驱动IOS测试原理关于 WebDriverAgent 基础环境搭建基础环境 安装内容前提环境通用环境iOS 环境iOS 真机调试环境配置IOS自动化-WebDriverAgent-APPIUM框架原理 利用Appium-Python-Client进行iOS的自动化…

基于Appium的ios自动化教程

Appium作为一个开源的、跨平台的自动化测试工具&#xff0c;适用于测试原生或混合型移动App&#xff0c;它使用WebDriver协议驱动IOS&#xff0c;Android和Windows应用程序&#xff0c;本篇文章介绍实现ios自动化测试 01、Appium实现iOS自动化测试 01、启动应用 填写 capabi…

从0开始的ios自动化测试

最近由于工作内容调整&#xff0c;需要开始弄ios自动化了。网上信息有点杂乱&#xff0c;这边我就按我的实际情况&#xff0c;顺便记录下来&#xff0c;看是否能帮到有需要的人。 环境准备 安装tidevice pip3 install -U “tidevice[openssl]” 它的作用是&#xff0c;帮你绕…

iOS自动化测试之基于模拟器的自动化测试

本文来自霍格沃兹测试开发学社 本文节选自霍格沃兹测试学院内部教材 本章节主要讲解 WebDriverAgent 环境搭建以及如何通过 iOS模拟器完成自动化。 WebDriverAgent简介 WebDriverAgent 是在 iOS 客户端启动了 WebDriver 的 Server&#xff0c;借助这个 server&#xff0c;可以…

【iOS自动化测试】第二章:环境安装

环境依赖 本文采用Win下搭建Appium环境调试iOS设备&#xff0c;Mac下结合jenkins运行出报告 Appium Desktop&#xff08;提供元素定位&#xff0c;服务等&#xff09; Appium Desktop 下载地址python3&#xff08;代码脚本编写&#xff09;Web DriverAgent Appium根据Facebookw…

iOS代码设计学习

组件设计 组件/模块,可以理解成【独立的业务或者功能单位】。至于这个单位的粒度大小&#xff0c;需要自己把握。当写一个类的时候&#xff0c;应该按照高内聚&#xff0c;低耦合的原则去设计该类&#xff0c;涉及多个类之间交互&#xff0c;运用SOLID原则&#xff0c;或其它已…

IOS 自动化

python airtest poco ios真机 case文件&#xff1a; ExecuteCodeIos.text 废话不多说直接上代码&#xff1a; # # -*- encodingutf8 -*- __author__ "UI自动化 ios 脚本"from airtest.core.api import * from poco.drivers.ios import iosPoco import os# 钉…

IOS自动化测试环境搭建(Python Java)

一、前言 IOS的App自动化测试与Android的一样&#xff0c;也可以用appium来进行。但是IOS自动化依赖苹果的osx系统、Xcode构建等&#xff0c;且封闭的系统需要苹果开发者账号才可以驱动真机。Appium的环境配置有点麻烦&#xff0c;可能大部分时间都在处理各种稀奇古怪的报错&am…

【iOS自动化测试】第三章:框架设计

框架总体 pytestallureappium 采用po分层设计集成到jenkins运行 框架结构 名称作用备注BasePage存放相应的封装方法基类层Pages页面层用于元素的定位封装页面层TestCases编写测试用例用例层Report存放报告报告层Public公共的调用方法公共层Log日志存放位置日志层Image用于存放…

iOS自动化测试的那些干货

前言 如果有测试大佬发现内容不对&#xff0c;欢迎指正&#xff0c;我会及时修改。 大多数的iOS App(没有持续集成)迭代流程是这样的 也就是说&#xff0c;测试是发布之前的最后一道关卡。如果bug不能在测试中发现&#xff0c;那么bug 就会抵达用户&#xff0c;所以测试的完整…

iOS自动化,知识点1

知识点1&#xff1a; 初始化连接手机 1.查找udid和包名 2&#xff0c;appium连接ios手机的条件 from appium import webdriver from selenium.webdriver.common.by import By import timedef test_01():desired_caps dict()desired_caps["platformName"]"iOS&…

2023主流技术 Appium+IOS 自动化测试环境搭建

关于Appium for IOS Appium是目前最主流的app自动化测试技术&#xff0c;能够同时支持IOS、Android平台上的移动应用自动化测试&#xff0c;能支持众多语言&#xff0c;包括&#xff1a;Java、Python、Ruby、JavaScript等&#xff1b;并且Appium是开源免费使用的。 目前网上的…

ios自动化-1阶段

使用pytestwda执行自动化 整体结构代码层级 #目前待改进的地方 1.执行速度慢&#xff0c;wda获取dom树的效率太低 2.稳定性差&#xff0c;经常会出现一些弹窗导致失败&#xff0c;可参考安卓弹窗处理 watcher() 优化 3.有部分元素定位不到&#xff0c;目前怀疑是层级问题&…

Visio 画流图 程序流图 斜线

如果直接在Visio中选择连接线来连接&#xff0c;会有直角出现&#xff0c;但是我们需要斜线&#xff1a; 解决方法&#xff1a; 选中直角连接线&#xff0c;右键&#xff0c;选择“直线连接线”&#xff1a; 这样我们就能画出想要的斜线了&#xff0c;也就可以画出程序流图了…

Visio设置跨线之间不避让

文章目录 设置方法1. 选中所需设置的直线&#xff1b;2. 菜单选中设计&#xff1b;3. 选中连接线&#xff1b;4. 选中显示跨线。 设置方法 1. 选中所需设置的直线&#xff1b; 2. 菜单选中设计&#xff1b; 3. 选中连接线&#xff1b; 4. 选中显示跨线。

Visio画ER图

建立数据库时我们需要考虑数据之间的关系&#xff0c;为了理清数据之间的关系我们需要对数据进行统一的整理。对于较复杂的数据库我们需要建立数据库模型&#xff0c;具体可分为两步&#xff1a;首先对数据库进行结构分析并使用树、表等描述数据&#xff0c;然后分析数据库的操…

visio 教程-绘图技巧、快捷键大全

visio 绘图技巧、快捷键大全&#xff0c;一键对齐 前言一、常用快捷键二、使用技巧对象移动对象复制绘制直线一键对齐 自动排列&#xff08;非常好用&#xff09;辅助线对齐图像边缘空白消除word中visio图编辑技巧去掉直线交叉点增加连接点 前言 Visio 是Office软件系列中的负…

visio画太极图

步骤一 添加两个圆&#xff0c;且大圆的半径是小圆的2倍。 步骤二 往小圆添加一条直线作为直径 步骤三 选中小圆和直径,依次点击开发工具–操作–连接&#xff0c;然后选中连接后的小圆&#xff0c;再依次点击开发工具–操作–修建&#xff0c;可以分离出如下所示的两个…