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

这篇具有很好参考价值的文章主要介绍了Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一 . 前言

由于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(官方)
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地

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

Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地
6.2.6 查询JDK版本信息

$ java -version

Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地
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

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

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文件
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地

在主函数中添加产生报告的代码 ,注意:路径应该与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即可
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地

8. 安装git

方式一:

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

方式二:

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

brew install git

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

git --version

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

9. 安装node

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

10. 安装jenkins

使用brew安装可能会存在更新的问题,小编这边使用包安装方式
安装地址:jenkins(官方)
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地

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 的方案;
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地
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文件进行配置

Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地配置完成之后,真机连接mac,使用command+u运行,ios上会自动安装一个runner程序,这是我们需要去手机设置描述文件信任该程序,运行成功后xcode控制台打印已下信息表示成功
Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地

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 LoggerUtil

logger = LoggerUtil()

class InitDevices(object):
    driver: webdriver = None

    @classmethod
    def 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] = v
                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
        else:
            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

    @classmethod
    def quit(cls):
        """
        关闭driver对象
        :return:
        """
        cls.driver.quit()

if __name__ == '__main__':
    comm = InitDevices.start('4723', noReset=True)
    time.sleep(1)
    comm.quit()

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

Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地文章来源地址https://www.toymoban.com/news/detail-445697.html

到了这里,关于Appium+Python+Pytest+Allure+Git+Node+Jenkins+Xcode IOS自动化测试从0到1落地的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • APP自动化测试-Python+Appium+Pytest+Allure框架实战封装(详细)

    pytest只是单独的一个单元测试框架,要完成app测试自动化需要把pytest和appium进行整合,同时利用allure完成测试报告的产出。 编写常规的线性脚本具体的步骤如下: 1、设计待测试APP的自动化测试用例 2、新建app测试项目 3、配置conftest.py文件等 4、编写整体app测试用例运行文件

    2024年02月14日
    浏览(36)
  • Python、Pytest、Allure、Selenium和Jenkins实现自动化测试集成实例

    下方查看历史精选文章 重磅发布 - 自动化框架基础指南pdfv1.1 大数据测试过程、策略及挑战 测试框架原理,构建成功的基石 在自动化测试工作之前,你应该知道的10条建议 在自动化测试中,重要的不是工具 本文将介绍如何使用Python、Pytest、Allure、Selenium和Jenkins实现测试自动

    2024年02月09日
    浏览(32)
  • pytest+requests+Python3.7+yaml+Allure+Jenkins+docker实现接口自动化

    目录 接口自动化测试框架(用例自动生成) 项目说明 技术栈 环境部署 框架流程图与目录结构图及相关说明 1、框架流程图如下 2、代码目录结构图如下 关联详解 函数助手详解 代码设计与功能说明 1、定义运行配置文件 runConfig.yml 2、接口配置文件 apiConfig.ini 3、测试用例的设

    2024年02月09日
    浏览(42)
  • 【自动化测试】Pytest+Appium+Allure 做 UI 自动化的那些事

    文本主要介绍下 Pytest+Allure+Appium 记录一些过程和经历。 法主要用了啥: Python3 Appium Allure-pytest Pytest Appium 不常见却好用的方法 Appium 直接执行 adb shell 方法 #Appium 启动时增加 --relaxed-security 参数 Appium 即可执行类似adb shell的方法 appium -p 4723 --relaxed-security #使用方法 def adb_shell(se

    2024年01月25日
    浏览(33)
  • Yaml版接口自动化详细讲解(Python + pytest + allure + log + yaml + mysql + redis + 钉钉通知 + Jenkins)

    目录 框架介绍 框架结构 框架功能讲解 common  # 配置         config.yaml  # 公共配置         setting.py  # 环境路径存放区域 data  # 测试用例数据 Files  # 上传文件接口所需的文件存放区域 logs  # 日志层 report  # 测试报告层 test_case  # 测试用例代码         __init

    2024年02月13日
    浏览(113)
  • 【Pytest实战】Pytest+Allure+Jenkins自动化测试框架搭建

    😄作者简介: 小曾同学.com,一个致力于测试开发的博主⛽️,主要职责:测试开发、CI/CD 如果文章知识点有错误的地方,还请大家指正,让我们一起学习,一起进步。😊 座右铭:不想当开发的测试,不是一个好测试✌️。 如果感觉博主的文章还不错的话,还请点赞、收藏哦

    2024年02月15日
    浏览(38)
  • 基于docker搭建pytest自动化测试环境(docker+pytest+jenkins+allure)

    这里我以ubuntu18为例 如果有docker环境,可以直接拉取我打包好的镜像 docker pull ziyigun/jenkins:v1.0 1.1 安装docker 1.2 配置镜像加速 bug1:ExecStart=/usr/bin/dockerd -H fd:// 如果发现docker启动或者重启报错: ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock (code=exited, status=1/FAILU

    2024年02月12日
    浏览(32)
  • Pytest+selenium+allure+Jenkins自动化测试框架搭建及使用

    一、    环境搭建 1.    Python下载及安装 Python可应用于多平台包括windows, Linux 和 Mac OS X, 本文主要介绍windows环境下。你可以通过终端窗口输入 \\\"python\\\" 命令来查看本地是否已经安装Python以及Python的安装版本。     如未安装python, 推荐下载python 3.8.3以上版本,本文主要介绍window

    2024年01月18日
    浏览(33)
  • 测开新手:pytest+requests+allure自动化测试接入Jenkins学习

    2024软件测试面试刷题,这个小程序(永久刷题),靠它快速找到工作了!(刷题APP的天花板) 最近在这整理知识,发现在pytest的知识文档缺少系统性,这里整理一下,方便后续回忆。 在python中,大家比较熟悉的两个框架是unittest和pytest: Unittest是Python标准库中自带的单元测

    2024年02月01日
    浏览(32)
  • pytest + yaml 框架 -60.git+jenkins+allure+钉钉通知反馈

    当我们自动化用例写完后,接下来就是如何运行用例,生成报告以及反馈通知了。 如果你们公司已经有jenkins了,那么直接集成到jenkins上构建你的自动化任务是非常方便的。 第一步,将写好的自动化用例,上传到本公司的git仓库。 在jenkins上创建一个自由风格的项目 源码管理

    2024年02月04日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包