UI自动化测试保姆级教程--pytest详解(精简易懂)

news2025/1/9 11:27:18

在这里插入图片描述

欢迎来到啊妮莫的学习小屋
别让过去的悲伤,毁掉当下的快乐一《借东西的小人阿莉埃蒂》

在这里插入图片描述

简介

pytest是一个用于Python的测试框架, 支持简单的单元测试和复杂的功能测试. 和Python自带的UnitTest框架类似, 但是相比于UnitTest更加简洁, 效率更高.

特点

  1. 非常容易上手, 入门简单, 文档丰富, 文档中有很多实例可以参考

    官方文档地址: pytest: helps you write better programs — pytest documentation

  2. 支持简单的单元测试和复杂的功能测试.

  3. 支持参数化: UnitTest需要通过插件扩展参数化功能!

  4. 执行测试过程中可以将某些测试跳过, 或者对某些预期失败的Case标记成失败

  5. 支持重复执行失败的Case: 通过安装插件实现

  6. 支持运行UnitTest编写的测试Case

  7. 具有很多第三方插件, 并且可以自定义扩展

    插件获取网站: Pytest Plugin List - pytest documentation

安装

# 安装命令
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pytest
# 查看
pip show pytest
# 确认版本
pytest --version

在这里插入图片描述

基本使用

测试函数形式

# 函数形式
def test_func():# 要求函数必须以test开头
    '''测试函数'''
    print('测试函数001')

运行结果:

在这里插入图片描述

测试类形式

# 类形式
class TestDemo(object):  # 类名必须以Test开头
    def test_method_01(self):  # 方法名必须以test开头
        '''测试方法 1'''
        print('测试方法 1')

    def test_method_02(self):
        '''测试方法 2'''
        print('测试方法 2')

    def text(self):
        '''不以test开头的方法'''
        print('text方法')

运行结果:

在这里插入图片描述

注意点:

类名以Test开头, 函数名或方法名以test开头, 否则不予执行

主函数执行

上述两种执行方式均为终端命令执行; pytest同时支持主函数执行, 只需要加入以下代码片段:

# 导包
import pytest

if __name__ == '__main__':
    pytest.main(['-s','执行文件名称'])

以下以上述测试类形式为例:

# 类形式
class TestDemo(object):  # 类名必须以Test开头
    def test_method_01(self):  # 方法名必须以test开头
        '''测试方法 1'''
        print('测试方法 1')

    def test_method_02(self):
        '''测试方法 2'''
        print('测试方法 2')

    def text(self):
        '''不以test开头的方法'''
        print('text方法')

if __name__ == '__main__':
    pytest.main(['-s','hm04_pytest_basic_04.py'])

动图演示效果:

在这里插入图片描述

特殊方法

函数级别
class TestDemo(object):  
    
    def setup_method(self):
        '''用例前执行准备工作'''
        pass
    def teardown_method(self):
        '''用例后扫尾工作'''
        pass

注意: 特殊方法名写法固定:setup_method 和 teardown_method, 没有代码提示, 需要手写.

代码示例:

# 类形式
class TestDemo(object):  # 类名必须以Test开头
    def setup_method(self):
        '''用例前执行准备工作'''
        print('开始测试')
    def teardown_method(self):
        '''用例后扫尾工作'''
        print('结束测试')
    def test_method_01(self):  # 方法名必须以test开头
        '''测试方法 1'''
        print('测试注册逻辑代码...')

    def test_method_02(self):
        '''测试方法 2'''
        print('测试登陆逻辑代码...')

if __name__ == '__main__':
    pytest.main(['-s','pytest_basic_05.py'])

运行结果:

在这里插入图片描述

类级别
class TestDemo(object):  # 类名必须以Test开头
    def setup_class(self):
        '''用例前执行准备工作'''
        pass
        
    def teardown_class(self):
        '''用例后扫尾工作'''
        pass

注意: 与函数级别的特殊方法一致, setup_class 和 teardown_class也是写法固定的.

代码示例:

# 类形式
class TestDemo(object):  # 类名必须以Test开头
    def setup_class(self):
        '''用例前执行准备工作'''
        print('开始测试')
    def teardown_class(self):
        '''用例后扫尾工作'''
        print('结束测试')
    def test_method_01(self):  # 方法名必须以test开头
        '''测试方法 1'''
        print('测试注册逻辑代码...')

    def test_method_02(self):
        '''测试方法 2'''
        print('测试登陆逻辑代码...')

if __name__ == '__main__':
    pytest.main(['-s','pytest_basic_06.py'])

运行结果:

在这里插入图片描述

执行顺序

执行顺序:
setup_class() --> setup_method() --> 测试方法 1 --> teardown_method() -->setup_method() --> 测试方法 2 --> teardown_method() --> (以此类推) -->teardown_class()

代码示例:

# 类形式
class TestDemo(object):  # 类名必须以Test开头
    def setup_class(self):

        print('开始测试 类级别')

    def teardown_class(self):

        print('结束测试 类级别')
    def setup_method(self):

        print('开始测试 函数级别')

    def teardown_method(self):

        print('结束测试 函数级别')

    def test_method_01(self):  # 方法名必须以test开头
        '''测试方法 1'''
        print('测试注册逻辑代码...')

    def test_method_02(self):
        '''测试方法 2'''
        print('测试登陆逻辑代码...')

if __name__ == '__main__':
    pytest.main(['-s','pytest_basic_07.py'])

运行结果:

在这里插入图片描述

pytest配置文件

使用pytest.ini配置文件后可以快速的使用配置的项来选择执行哪些测试模块

注意:

1.在Windows系统中, pytest.ini配置文件中, 不可以写注释

2.一个工程中只需要一个pytest配置文件, 并且需要保证文件名正确

3.一般情况下, 只需要将pytest.ini 置于工程根目录下

4.配置有pytest.ini的文件, 只需要在终端输入pytest指令, 即可执行测试

pytest配置项有很多, 可以在终端输入pytest --help来执行

在这里插入图片描述

配置文件示例:

[pytest]
testpaths = ./
addopts = -s
python_files=pytest*.py
python_classes=Test*
python_functions=test*

在这里插入图片描述

输入pytest指令执行结果:

在这里插入图片描述

注意: 默认情况下 测试文件名/类名/方法函数名 均以Test或test开头.

当然我们可以通过配置文件进行自定义. 例如:测试类名以 CeShi 开头

[pytest]
testpaths = ./
addopts = -s
python_files=test*.py
python_classes=CeShi*
python_functions=test*

例如:指定某一个 文件/类/方法 执行 (指定pytest_basic_06.py)

[pytest]
testpaths = ./
addopts = -s
python_files=pytest_basic_06.py
python_classes=CeShi*
python_functions=test*

pytest常用插件

pytest拥有很多第三方插件. 以下介绍几个常用的.

HTML报告插件

pytest-html是pytest的一个插件, 可以为测试结果生成HTML报告.

安装
pip install pytest-html
使用步骤

在pytest.ini文件中添加参数选项:

--html=./报告路径/报告  #指定报告文件的存放位置(会自动创建)
--self-contained-html  #将CSS文件内嵌到HTML文件中

配置文件示例:

[pytest]
testpaths = ./
addopts = -s
          --html=./report/report.html
          --self-contained-html
python_files=pytest*.py
python_classes=Test*
python_functions=test*

输入pytest指令执行结果:

在这里插入图片描述

查看报告

在这里插入图片描述

控制方法执行顺序插件

在使用Python进行单元测试或者集成测试的时候, 通常测试用例的执行顺序是自动排序的. 不过在某些情况下, 特别是当测试用例存在依赖关系的时候, 我们可能希望自定义测试的执行顺序.Python提供了一个实用的插件–>pytest-ordering

安装
pip install pytest-ordering
使用步骤

直接在测试类测试方法上方添加以下代码:

@pytest.mark.run(order=序号)

注意:
序号支持正负数;
纯正数或者纯负数:数字越小,优先级越高;
正负混合:正数先按序执行, 再负数按序执行;

代码示例:

import pytest

class TestDemo(object):  # 类名必须以Test开头
    @pytest.mark.run(order=-5)
    def test_method_01(self):  # 方法名必须以test开头
        '''测试方法 1'''
        print('测试方法 1...')

    @pytest.mark.run(order=-2)
    def test_method_02(self):
        '''测试方法 2'''
        print('测试方法 2...')

    @pytest.mark.run(order=2)
    def test_method_03(self):
        '''测试方法 3'''
        print('测试方法 3...')


if __name__ == '__main__':
    pytest.main(['-s', 'pytest_basic_08.py'])

运行结果:

在这里插入图片描述

失败重试插件

pytest-rerunfailures是一个基于pytest框架的插件, 它允许我们对测试用例进行失败重试.

安装
pip install pytest-rerunfailures
使用步骤

在pytest.ini文件中添加参数选项:

--reruns 次数  #指定失败后的执行次数

配置文件示例:

[pytest]
testpaths = ./
addopts = -s
          --html=./report/report.html
          --self-contained-html
          --reruns 1  
python_files=pytest*.py
python_classes=Test*
python_functions=test*

创建一个测试用例文件, 包含异常代码:

# 类形式
class TestDemo(object):  # 类名必须以Test开头
    def test_method(self):  # 方法名必须以test开头
        '''错误代码'''
        print(f"num={10/0}")

终端输入pytest运行结果:

在这里插入图片描述

pytest高级功能

跳过操作

对于完成的代码或者版本不对应的代码, 可以设置跳过让代码不执行

在测试类/方法上方添加以下代码:

@pytest.mark.skipif(符合的条件, reason='跳过的原因')

代码示例:

import pytest

class TestDemo(object):  # 类名必须以Test开头

    version = 2.5

    @pytest.mark.skipif(version <= 5, reason='版本过低,测试用例失效')
    def test_method_01(self):  # 方法名必须以test开头
        '''测试方法 1'''
        print('测试方法 1...\n')

    version = 5.6

    @pytest.mark.skipif(version <= 5, reason='版本过低,测试用例失效')
    def test_method_02(self):
        '''测试方法 2'''
        print('测试方法 2...\n')

    version = 7.0

    @pytest.mark.skipif(version <= 5, reason='版本过低,测试用例失效')
    def test_method_03(self):
        '''测试方法 3'''
        print('测试方法 3...\n')


if __name__ == '__main__':
    pytest.main(['-s', 'pytest_basic_09.py'])

运行结果:

在这里插入图片描述

参数化操作

pytest框架自带参数化功能, 调用对应方法并传入数据, 即可完成参数化实现.

@pytest.mark.parametrize('参数1, 参数2', [(数据1-1,数据1-2),(数据2-1,数据2-2)] )
# 同组数据之间用 , 分割, 不同组数据之间用 () 分割
def test_method_01(self,参数1,参数2):  
	pass

注意: 测试方法中需要传入参数名

代码示例:

import pytest

class TestDemo(object):  # 类名必须以Test开头
    # 单个参数
    @pytest.mark.parametrize('stu',[('张三'),('李四'),('王五')])
    def test_method_01(self,stu):  # 方法名必须以test开头
        '''测试方法 1'''
        print('学生名字:',stu)

    # 多个参数
    @pytest.mark.parametrize('用户名, 密码', [('zs', '12345'), ('lisi', 'abcde'), ('wwu', '01010')])
    def test_method_02(self,用户名,密码):
        '''测试方法 2'''
        print(f'用户名:{用户名} && 密码:{密码}')


if __name__ == '__main__':
    pytest.main(['-s', 'pytest_basic_10.py'])

运行结果:

在这里插入图片描述

断言操作

UnitTest框架不同的是, pytest框架使用的是Python自带的断言–assert

代码示例:

import pytest

class TestDemo(object):  # 类名必须以Test开头

    # 多个参数
    @pytest.mark.parametrize('用户名, 密码', [('zs', '12345'), ('lisi', 'abcde'), ('wwu', '01010')])
    def test_method_01(self, 用户名, 密码):
        '''测试方法 2'''
        # assert 条件
        # 如果不满足条件则会断言报错
        assert 密码 != '01010'
        print(f'用户名:{用户名} && 密码:{密码}')

if __name__ == '__main__':
    pytest.main(['-s', 'pytest_basic_11.py'])

运行结果:

在这里插入图片描述

感谢铁汁萌花时间来看我写的文章~ 以上就是本篇文章的所有内容了, 如果对你有所帮助的话, 还请给我点一个小小的赞哦~💖 期待你的关注和三连🌈🌈

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

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

相关文章

有序数据中插入不确定数据保证数据插入的位置顺序正确排序

解决有序数据中插入不确定数据保证数据插入的位置顺序正确排序 前言 java 数据库中存储自增id 有序的数据&#xff0c; 前端页面基于 id 5和 6 之间新增一条数据&#xff0c;在 id 6 和 7之间新增 2条&#xff0c;或者更复杂的场景&#xff0c;后台接口如何保存数据使得页面数…

基于 Apache Commons Pool 实现的 gRPC 连接池管理类 GrpcChannelPool 性能分析与优化

基于 Apache Commons Pool 实现的 gRPC 连接池管理类 GrpcChannelPool 性能分析与优化 1. 输出关键信息的代码示例 日志记录方法 使用以下代码记录连接池的关键信息&#xff0c;帮助分析连接池的状态和性能瓶颈&#xff1a; import org.apache.commons.pool2.impl.GenericO…

不同方式获取音频时长 - python 实现

DataBall 助力快速掌握数据集的信息和使用方式&#xff0c;会员享有 百种数据集&#xff0c;持续增加中。 需要更多数据资源和技术解决方案&#xff0c;知识星球&#xff1a; “DataBall - X 数据球(free)” -------------------------------------------------------------…

在 C# 中显示动画 GIF 并在运行时更改它们

您可以通过将按钮、图片框、标签或其他控件的Image属性设置为 GIF 文件 来显示动画 GIF 。&#xff08;如果您在窗体的BackgroundImage属性中显示一个&#xff0c;则不会获得动画。&#xff09; 有几种方法可以在运行时更改 GIF。 首先&#xff0c;您可以将 GIF 添加为资源。…

Element-plus、Element-ui之Tree 树形控件回显Bug问题。

需求&#xff1a;提交时&#xff0c;需要把选中状态和半选中状态 的数据id提交。如图所示&#xff1a; 数据回显时&#xff0c;会出现代码如下&#xff1a; <template><el-tree ref"treeRef" :data"data" show-checkbox node-key"id" …

【江协STM32】9-1/2/3 USART串口协议、USART外设、串口发送串口发送+接收

1. 通信接口 通信的目的&#xff1a;将一个设备的数据传送到另一个设备&#xff0c;扩展硬件系统通信协议&#xff1a;制定通信的规则&#xff0c;通信双方按照协议规则进行数据收发全双工&#xff1a;指通信双方能够同时进行双向通信。发送线路和接收线路互不影响&#xff0c…

小程序租赁系统开发的优势与应用前景分析

内容概要 小程序租赁系统是一种新兴的数字化解决方案&#xff0c;旨在为用户提供更加便捷与高效的租赁服务。它通常包括一系列功能&#xff0c;如在线浏览、即时预定、支付功能以及用户反馈机制。这些系统在使用上极为友好&#xff0c;让用户能够轻松选择所需的商品或服务&…

25/1/8 算法笔记<强化学习> GYM环境

前几天花了好多时间在装各个仿真环境上&#xff0c;有V-rep,Pybullet,unity的Ml-agent,很多一大堆&#xff0c;好多好多问题差点逼疯我&#xff0c;可能就pybullet能玩一点&#xff0c;到之后学了机器人我再来玩它&#xff0c;最后的最后&#xff0c;我发现还得是我的gym&#…

学习随记:word2vec中归一化处理的作用

答案来自ai&#xff0c;直接复用为参考&#xff1a; 向量归一化的好处 将向量进行归一化&#xff0c;使其模长为 1&#xff08;即投射到单位圆/单位球上&#xff09;&#xff0c;在许多情况下具有实际意义和计算优势。以下是归一化的主要好处和原因&#xff1a; 1. 提高数值稳…

【C++】B2108 图像模糊处理

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目描述题目内容输入格式输出格式示例输入&#xff1a;输出&#xff1a; &#x1f4af;题目分析问题拆解 &#x1f4af;我的做法代码实现代码分析 &#x1f4af;老师的做法…

selenium+pyqt5自动化工具总结

说明&#xff1a;本工具是&#xff0c;操作外部google浏览器、selenium是无法操作qt界面中嵌套的浏览器的&#xff0c; 工具在后面 1. 代码结构 pycharm打开的文件下&#xff0c;再写一个子文件&#xff0c;文件导入的时候把子文件名带上 这样就可以在 外层使用命令 pyinst…

经典多模态模型CLIP - 直观且详尽的解释

对比语言-图像预训练&#xff08;CLIP&#xff09;&#xff0c;这是一种创新的多模态建模策略&#xff0c;能够创建视觉和语言的联合表示。CLIP 的效果非常出色&#xff0c;可以用于构建高度特定且性能卓越的分类器&#xff0c;而无需任何训练数据。本文将深入探讨其理论基础&a…

新时期下k8s 网络插件calico 安装

1、k8s master节点初始化完毕以后一直处于notreadey状态&#xff0c;一直怀疑是安装有问题或者是初始化有问题&#xff08;当然&#xff0c;如果真有问题要先解决这些问题&#xff09;&#xff0c;经过不断探索才发现是网络插件没有安装导致的&#xff0c;根据建议安装calico插…

【图像加密解密】Logistic混沌映射的彩色图像加密算法复现(含相关性检验)【Matlab完整源码 1期】

1、说明 本文给出详细完整代码、完整的实验报告和PPT。 环境&#xff1a;MATLAB2019a 复现文献&#xff1a;[1]黄硕.基于改进的Logistic混沌映射彩色图像加密算法[J].河南工程学院学报(自然科学版),2015,27(02):63-67. 主要目的是为了快速了解何为混沌序列、混沌序列产生、…

[AUTOSAR 基础入门] - RTE虚拟总线详解

文章目录 一、什么是RTE二、RTE的作用三、RTE对Runnables的运行支撑四、RTE与通信4.1. RTE – ECU之间通信4.2. RTE - Sender/Receiver 通信4.2.1 不使用队列&#xff08;直接访问&#xff09;4.2.2 不使用队列&#xff08;缓存访问&#xff09;4.2.3 使用队列 4.3 RTE - Clien…

Linux下文件操作相关接口

文章目录 一 文件是什么普通数据文件 二 文件是谁打开的进程用户 三 进程打开文件的相关的接口c语言标准库相关文件接口1. fopen 函数2. fread 函数3. fwrite 函数4. fclose 函数5. fseek 函数 linux系统调用接口1. open 系统调用2. creat 系统调用3. read 系统调用4. write 系…

用Python实现简单的任务自动化

目录 1. 自动发送邮件提醒 2. 自动备份文件 3. 自动下载网页内容 总结 在现代工作和生活中,任务自动化可以极大地提高效率和准确性。Python,作为一种功能强大且易于学习的编程语言,是实现任务自动化的理想选择。本文将通过几个简单而实用的案例,展示如何用Python实现任…

小程序开发-页面事件之上拉触底实战案例

&#x1f3a5; 作者简介&#xff1a; CSDN\阿里云\腾讯云\华为云开发社区优质创作者&#xff0c;专注分享大数据、Python、数据库、人工智能等领域的优质内容 &#x1f338;个人主页&#xff1a; 长风清留杨的博客 &#x1f343;形式准则&#xff1a; 无论成就大小&#xff0c;…

Docker 服务、镜像、容器之命令(Docker Services, Images, and Container Commands)

Docker 服务、镜像、容器之命令 Docker是一个强大的容器化平台&#xff0c;能够帮助开发者高效地构建、部署和管理应用程序。本文将详细介绍Docker的服务命令、镜像命令和容器命令&#xff0c;帮助你快速上手Docker。 一、Docker的服务相关命令 在使用Docker之前&#xff0c…

STM32内置Flash

一、原理 利用flash存储用户数据需要注意查看&#xff0c;用户数据是否会覆盖芯片运行程序。 IAP&#xff08;在程序中编程&#xff09;利用程序修改程序本身&#xff0c;和OTA是一个原理。IAP在程序中编程支持任意一种通信下载。 ICP&#xff08;在电路中编程&#xff0c;通…