当前位置: 首页 > news >正文

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命令,运行成功的结果如下图:
在这里插入图片描述



相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 02 vue3之ref全局桶
  • iOS工程:获取手机相册权限,iOS原生系统弹窗, Privacy隐私政策选择,如何添加系统弹出并修改描述文字
  • -- 数据结构 顺序表 --Java
  • TCP并发服务器多线程和多进程方式以及几种IO模型
  • 【Python】copy()浅拷贝与深拷贝
  • 【牛客_c++_string】HJ1字符串最后一个单词的长度
  • Spring Boot使用拦截器(Interceptor)
  • mysql中group by语句使用
  • 结果一。6.will,begoingto,betodo,beabouttodo结构的区别
  • 在CentOS 7上安装MongoDB的方法
  • ROS imu传感器节点
  • 书生大模型实战营-进阶关卡-6-MindSearch 快速部署
  • 力扣8.27
  • 阿里云对象存储服务(Aliyun OSS):企业级云存储解决方案
  • Spring Boot 集成 JdbcTemplate(盘它!)
  • php的引用
  • [ JavaScript ] 数据结构与算法 —— 链表
  • [译]CSS 居中(Center)方法大合集
  • 8年软件测试工程师感悟——写给还在迷茫中的朋友
  • Bootstrap JS插件Alert源码分析
  • Codepen 每日精选(2018-3-25)
  • Cookie 在前端中的实践
  • E-HPC支持多队列管理和自动伸缩
  • JS基础篇--通过JS生成由字母与数字组合的随机字符串
  • JS基础之数据类型、对象、原型、原型链、继承
  • Js基础知识(一) - 变量
  • Python连接Oracle
  • Webpack入门之遇到的那些坑,系列示例Demo
  • 嵌入式文件系统
  • 世界编程语言排行榜2008年06月(ActionScript 挺进20强)
  • 学习笔记TF060:图像语音结合,看图说话
  • 原生Ajax
  • 正则学习笔记
  • nb
  • raise 与 raise ... from 的区别
  • ‌分布式计算技术与复杂算法优化:‌现代数据处理的基石
  • # 数论-逆元
  • ###51单片机学习(1)-----单片机烧录软件的使用,以及如何建立一个工程项目
  • $ git push -u origin master 推送到远程库出错
  • (0)Nginx 功能特性
  • (1)STL算法之遍历容器
  • (7) cmake 编译C++程序(二)
  • (react踩过的坑)Antd Select(设置了labelInValue)在FormItem中initialValue的问题
  • (第27天)Oracle 数据泵转换分区表
  • (附源码)计算机毕业设计ssm高校《大学语文》课程作业在线管理系统
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (十五)使用Nexus创建Maven私服
  • (四)七种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • .bat批处理(一):@echo off
  • .gitignore
  • .NET 项目中发送电子邮件异步处理和错误机制的解决方案
  • .NET/C# 判断某个类是否是泛型类型或泛型接口的子类型
  • .NET开源的一个小而快并且功能强大的 Windows 动态桌面软件 - DreamScene2
  • ?php echo $logosrc[0];?,如何在一行中显示logo和标题?
  • @四年级家长,这条香港优才计划+华侨生联考捷径,一定要看!