Python测试框架之—— pytest介绍与示例

2024-08-25 12:20

本文主要是介绍Python测试框架之—— pytest介绍与示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Pytest是一个功能强大且易于使用的Python测试框架,它提供了丰富的功能和灵活的用法,使得编写和运行测试变得简单而高效。

一、Pytest的特点

  1. 简单灵活:Pytest的语法简洁清晰,容易上手,并且支持复杂的测试场景。
  2. 自动发现测试:Pytest能够自动发现项目中的测试文件和测试函数,无需手动编写繁琐的配置。
  3. 丰富的断言库:Pytest内置了丰富的断言库,可以方便地进行测试结果的判断。
  4. 支持参数化测试:Pytest支持参数化测试,允许对多组输入进行测试,提高测试效率。
  5. 插件丰富:Pytest拥有丰富的插件生态系统,如pytest-selenium(集成selenium)、pytest-html(生成HTML测试报告)、pytest-rerunfailures(失败case重复执行)、pytest-xdist(多CPU分发)等,可以通过插件扩展各种功能。
  6. 可以与Jenkins集成:Pytest能够很好地与Jenkins等持续集成工具集成,方便自动化测试流程的构建。

二、Pytest的安装

Pytest的安装非常简单,可以使用pip命令进行安装:


pip install -U pytest

安装完成后,可以通过运行pytest --version来验证安装是否成功,如果看到版本号则说明安装成功。

三、Pytest的基本使用

  1. 测试文件命名:测试文件应该以test_开头或以_test结尾,例如test_login.pyuser_test.py
  2. 测试函数命名:测试函数应该以test开头,例如def test_login_success():
  3. 测试类命名:如果使用类来组织测试用例,测试类应该以Test开头,且不能有__init__方法。测试类中的测试函数同样需要以test开头。
  4. 执行测试:可以通过命令行直接运行pytest命令来执行测试,或者通过编写Python代码调用pytest.main()函数来执行测试。

四、Pytest的运行参数

Pytest提供了丰富的运行参数,以支持不同的测试需求。以下是一些常用的运行参数:

  • -v:打印详细运行日志。
  • -s:打印测试中的print输出。
  • -k:通过关键字表达式过滤要执行的测试用例。
  • -x:运行用例失败后立即停止执行。
  • --maxfail=num:当用例失败数达到某个设定的值时停止运行。
  • -m:运行所有被特定标记装饰的测试用例。

五、Pytest的fixture

Pytest的fixture是一个非常强大的功能,它主要用于测试环境的初始化和清理工作。fixture可以代替传统的setup和teardown函数,提供更加灵活和强大的功能。

fixture通过@pytest.fixture()装饰器进行定义,可以使用scope参数控制fixture的作用范围(如function、class、module、session)。在测试用例中,可以通过函数参数的形式传入fixture,以便在测试前后进行环境的初始化和清理。

六、Pytest的断言

Pytest的断言主要使用Python的原生断言方法,如==inis等。此外,Pytest还提供了assert语句的扩展功能,可以方便地生成断言失败的详细信息。

七、Pytest的skip和xfail

Pytest支持在测试用例中跳过某些不需要执行的测试,或者将某些预期会失败的测试标记为xfail(expected failure)。这有助于在开发过程中管理那些尚未实现或存在已知问题的功能。

八、Pytest的示例

这里的Python项目的结构很简单,如下所示:

project/  
├── src/  
│   ├── module1.py  
│   └── module2.py  
└── tests/  ├── test_module1.py  └── test_module2.py

这里以实现斐波那契函数及对其进行测试为例:

斐波那契函数是一个有趣的古典数学问题,著名意大利数学家Fibonacci曾提出一个问题:有一对小兔子,从出生后第3个月起每个月都生一对兔子。小兔子长到第3个月后每个月又生一对兔子。按此规律,假设没有兔子死亡,第一个月有一对刚出生的小兔子,问第n个月有多少对兔子?

在src目录下新增 fibonacci.py , 内容如下:

def fibonacci(n):  if n <= 0:  return 0  elif n == 1:  return 1  a, b = 0, 1  for _ in range(2, n + 1):  a, b = b, a + b  return b  

在tests目录下新增测试文件:test_fibonacci.py,内容如下:

import pytest
import sys  
import os  # 获取当前文件的目录  
current_dir = os.path.dirname(os.path.abspath(__file__))  # 获取当前文件的父目录路径  
parent_dir = os.path.dirname(current_dir)  # 假设src目录与当前文件(test_fibonacci.py)在同一级别  
src_dir = os.path.join(parent_dir, 'src')  
# 将src目录添加到sys.path中,以便可以导入其中的模块  
sys.path.insert(0, src_dir)  # 现在可以导入src目录下的fibonacci模块了  
from fibonacci import fibonacci  def test_fibonacci_zero():  assert fibonacci(0) == 0  def test_fibonacci_one():  assert fibonacci(1) == 1  def test_fibonacci_two():  assert fibonacci(2) == 1  def test_fibonacci_three():  assert fibonacci(3) == 2  def test_fibonacci_four():  assert fibonacci(4) == 3  def test_fibonacci_large_number():  # 选择一个较大的数字进行测试,确保算法在较大输入时也能正确工作  # 这里选择了第10个斐波那契数,因为55是一个相对容易验证的结果  assert fibonacci(10) == 55  def test_fibonacci_negative_number():  # 假设我们想要函数对于负数的输入抛出异常或者返回特定的值  # 这里我们假设它应该返回0(或者你可以根据需求修改)  assert fibonacci(-1) == 0  

在项目目录运行 pytest命令,运行成功的结果如下图:
在这里插入图片描述



这篇关于Python测试框架之—— pytest介绍与示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1105543

相关文章

Python使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数

SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程

《SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程》本文详细介绍了如何在虚拟机和宝塔面板中安装RabbitMQ,并使用Java代码实现消息的发送和接收,通过异步通讯,可以优化... 目录一、RabbitMQ安装二、启动RabbitMQ三、javascript编写Java代码1、引入

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque