python单元测试框架pytest的使用示例

简介: python单元测试框架pytest的使用示例

这篇文章主要介绍了python单元测试框架pytest的使用示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们来一起学习学习吧

天天去图书馆学了几天,学习的感觉还是非常不错的,这是一篇总结。

这篇准备讲解一下pytest测试框架,这个框架是当前最流行的python语言最流行的单测框架,不掌握可不行,首先这个框架属于第三方模块,需要通过pip安装即可

pip install pytest

下面我们进入正题

一、介绍pytest的运行规则

1、测试文件的名称必须要以test_.py的格式,或者_test.py的格式

2、测试类的名称必须要以Test开头,且这个类还不能有构造方法(__init__)

3、测试函数的名称必须要以test开头

pytest默认的就按照上面的三条规则来执行案例,当然我们可以自定义运行规则,这个我们后面在讲,这个不重要,看一个最简单的例子

import os
import pytest
  
# pytest是python的单元测试框架
  
def func(x):
 return x + 1
  
  
def test_a():
 print("____test_a____")
 assert func(2) == 5
  
def test_b():
 print("____test_b____")
 assert func(2) == 3
  
if __name__ == '__main__':
 pytest.main(["-s","pytest1.py"])

二、介绍pytest的前置条件和后置条件,类似unittest的testfixture(测试固件)

如果同学们之前用过unittest测试框架,对测试固件这个这个名词就不会陌生了,如果不清楚,可以看下之前我写的unittest测试框架的博客小程序(全栈工具箱)

pytest框架的测试固件有两种,一种函数级别的,一种是类级别,执行的顺序如下

a、执行类的前置条件

b、执行函数的前置条件

c、执行函数的后置条件

d、执行类的后置条件

使用也非常简单,当时函数的命名一定要和我下面的备注保持完全一致

# pytest的前置和后置条件
  
# 1、函数级别 setup teardown
# 运行于测试方法的开始和结束
# 运行一个测试用例,会运行一次setup和teardown
  
# 2、类级 setup_class teardown_class
# 运行于测试类的开始和结束
# 一个测试类只运行一次setup_class teardown_class

1、函数式的案例--函数级别的前置条件&后置条件

import os
import pytest
  
def func(x):
 return x + 1
  
  
def test_a():
 print("____test_a____")
 assert func(2) == 5
  
def test_b():
 print("____test_b____")
 assert func(2) == 3
  
  
def setup():
 print("函数级别的前置")
  
def teardown():
 print("函数级别的后置")

执行结果如下

图片.png

2、类式的案例--函数级别的前置条件&后置条件

class Testclass:
 def test_a(self):
  print("____test_a____")
  assert func(2) == 5
  
 def test_b(self):
  print("____test_b____")
  assert func(2) == 3
  
 def setup(self):
  print("函数级别的前置")
  
 def teardown(self):
  print("函数级别的后置")
if __name__ == '__main__':
 pytest.main(["-s","pytest2.py"])

执行结果如下

图片.png

3、类级别的前置条件&后台置条件

import pytest
  
def func(x):
 return x + 1
  
  
class Testclass:
 def test_a(self):
  print("____test_a____")
  assert func(2) == 5
  
 def test_b(self):
  print("____test_b____")
  assert func(2) == 3
  
 def setup(self):
  print("函数级别的前置")
  
 def teardown(self):
  print("函数级别的后置")
   
 def setup_class(self):
  print("类级别的前置")
  
 def teardown_class(self):
  print("类级别的后置")
if __name__ == '__main__':
 pytest.main(["-s","pytest3.py"])

结果如下

图片.png

三、介绍如何修改pytest的配置文件

我们在博客的第一部分介绍了pytest框架的运行规则,这里我们可以修改pytest的配置文件,改变框架运行规则

首先我们要在案例的目录下创建一个pytest.ini的配置文件

图片.png

内容如下

# 创建pytest.ini文件
# [pytest]
# addopts=-s
#这个先这样写,这个主要是执行参数
  
  
# testpaths = testcase
# 只执行这个目录下的文件
#
# python_files = test_*.py
#执行的文件的名字
  
  
# python_classes = Test_*
#执行类的名字
  
# python_functions = test_*
# 执行函数的名字

配置文件截图

图片.png

通过上面的步骤,我们就可以改变pytest的运行规则

四、介绍pytest的断言

pytest的断言是用python的断言,他不像unittest框架,他自己实现了断言

# -*- coding:utf-8 -*-
  
# pytest是使用python自带的断言
import pytest
  
def func(x):
 return x + 1
  
  
def test_a():
 print("____test_a____")
 assert func(2) == 5
  
def test_b():
 print("____test_b____")
 assert not func(2) == 3
  
def test_c():
 print("____test_b____")
 assert func(2) in ["a","b","c"]
  
  
def test_d():
 print("____test_b____")
 assert func(2) not in ["a","b","c"]
  
  
if __name__ == '__main__':
 pytest.main(["-s","pytest5.py"])

五、介绍pytest的标记(mark)

1、可以实现给函数打标记,实现哪些标记执行,哪些标记不执行

一个函数可以打多个标记,一个标记同时可以给多个函数打标记。只需要让这个标记的装饰器函数装饰我们的测试类或者测试函数

class Test_mark():
 @pytest.mark.test01
 def test_a(self):
  print("mark test a")
  
 @pytest.mark.test02
 def test_b(self):
  print("mark test b")
  
  
if __name__ == '__main__':
 pytest.main(['-s',"pytest6.py"])

还有其它的执行方式

# pytest -m test01
  
# pytest -n "test01 or test02"
  
# pytest -m "not test01"

2、标记可以实现不跳过某个、某些案例的作用

# -*- coding:utf-8 -*-
  
import pytest
  
# skip跳过执行某个案例
@pytest.mark.skip(reson="只是这个函数用例不执行")
def test_a():
  
 print("testa")
  
  
def test_b():
 print("testb")
  
  
@pytest.mark.skip(reson="整个类下的案例都不会执行")
class Test_skip():
 def test_a(self):
  print("testa")
  
 def test_b(self):
  print("testb")
  
  
# 可以根据条件判断,为真,则不执行
@pytest.mark.skipif(1 > 2,reson="整个类下的案例满足条件都不会执行")
class Test_skipif():
 def test_a(self):
  print("testa")
  
 def test_b(self):
  print("testb")

六、介绍pytest的数据参数化

1、传入单个参数

# pytest的数据参数化
  
# 1、传入单个参数
#
# pytest.mark.parametrize(argnames,argvalues)
# argnames 参数的名称
#
# argvalues 参数对应的值,类型必须是可迭代的类型,一般使用list
  
  
@pytest.mark.skip(reson="只是这个函数用例不执行")
def test_a():
 print("testa")
  
  
@pytest.mark.parametrize("name",["cui1","cui2","cui3","cui4"])
def test_b(name):
 print("testb----->{name}".format(name = name))
  
if __name__ == '__main__':
 pytest.main(["-s", "pytest8.py"])

实现的效果name作为参数的名称,这个案例会执行4次,参数分别是name=“cui1”\name="cui2"....

图片.png

2、传入多个参数

import pytest
  
  
# pytest的数据参数化
  
# 1、传入多个参数
#
# pytest.mark.parametrize((argnames1,argnames2),[(argvalues1,argvalues1),(argvalues1,argvalues1)],(argvalues1,argvalues1)]])
  
  
@pytest.mark.skip(reson="只是这个函数用例不执行")
def test_a():
 print("testa")
  
  
@pytest.mark.parametrize(("name","age"),[("cui1",12),("cui2",13),("cui3",14)])
def test_b(name,age):
 print("testb----->{name}----->{age}".format(name = name,age = age))
  
if __name__ == '__main__':
 pytest.main(["-s", "pytest9.py"])

实现的效果如下

图片.png

七、介绍pyest的常用第三方插件

1、美化pytest的输出报告插件

# pip install pytest-html
  
# 用来美化输出报告的插件
# 只需要在配置文件中加这个配置即可
#
# addopts=-s --html=report.html

效果

图片.png

图片.png

2、失败案例重试插件,下面的示例实现的就是失败重启3,失败后间隔2s在进行重试

# pip install pytest-rerunfailures
# 失败重试的第三方插件
# 只需要在配置文件中加这个配置即
# --reruns 3 --reruns-delay 2

至此,pytest的框架基本使用已经讲解清楚,小伙伴们还有不清楚的吗?欢迎大家来沟通!!!

到此这篇关于python单元测试框架pytest的使用示例的文章就介绍到这了,更多相关python单元测试框架pytest内容请搜索"软件测试pytest"以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关文章
|
26天前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
81 8
|
13天前
|
IDE 测试技术 开发工具
10个必备Python调试技巧:从pdb到单元测试的开发效率提升指南
在Python开发中,调试是提升效率的关键技能。本文总结了10个实用的调试方法,涵盖内置调试器pdb、breakpoint()函数、断言机制、logging模块、列表推导式优化、IPython调试、警告机制、IDE调试工具、inspect模块和单元测试框架的应用。通过这些技巧,开发者可以更高效地定位和解决问题,提高代码质量。
106 8
10个必备Python调试技巧:从pdb到单元测试的开发效率提升指南
|
10天前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
103 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
1天前
|
存储 测试技术 API
pytest接口自动化测试框架搭建
通过上述步骤,我们成功搭建了一个基于 `pytest`的接口自动化测试框架。这个框架具备良好的扩展性和可维护性,能够高效地管理和执行API测试。通过封装HTTP请求逻辑、使用 `conftest.py`定义共享资源和前置条件,并利用 `pytest.ini`进行配置管理,可以大幅提高测试的自动化程度和执行效率。希望本文能为您的测试工作提供实用的指导和帮助。
31 15
|
22天前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
54 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
27天前
|
安全 Ubuntu Linux
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
44 9
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
|
25天前
|
数据可视化 Python
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
通过这些思维导图和分析说明表,您可以更直观地理解和选择适合的数据可视化图表类型,帮助更有效地展示和分析数据。
64 8
|
1月前
|
API Python
【Azure Developer】分享一段Python代码调用Graph API创建用户的示例
分享一段Python代码调用Graph API创建用户的示例
51 11
|
1月前
|
Java 测试技术 API
探索软件测试中的自动化测试框架
本文深入探讨了自动化测试在软件开发中的重要性,并详细介绍了几种流行的自动化测试框架。通过比较它们的优缺点和适用场景,旨在为读者提供选择合适自动化测试工具的参考依据。
|
1月前
|
数据管理 jenkins 测试技术
自动化测试框架的设计与实现
在软件开发周期中,测试是确保产品质量的关键步骤。本文通过介绍自动化测试框架的设计原则、组件构成以及实现方法,旨在指导读者构建高效、可靠的自动化测试系统。文章不仅探讨了自动化测试的必要性和优势,还详细描述了框架搭建的具体步骤,包括工具选择、脚本开发、执行策略及结果分析等。此外,文章还强调了持续集成环境下自动化测试的重要性,并提供了实际案例分析,以帮助读者更好地理解和应用自动化测试框架。