- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章python单元测试框架pytest的使用示例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
首先祝大家国庆节日快乐,这个假期因为我老婆要考注会,我也跟着天天去图书馆学了几天,学习的感觉还是非常不错的,这是一篇总结.
这篇博客准备讲解一下pytest测试框架,这个框架是当前最流行的python语言最流行的单测框架,不掌握可不行,首先这个框架属于第三方模块,需要通过pip安装即可 。
pip install pytest
下面我们进入正题 。
1、介绍pytest的运行规则 。
1、测试文件的名称必须要以test_*.py的格式,或者*_test.py的格式 。
2、测试类的名称必须要以Test开头,且这个类还不能有构造方法(__init__) 。
3、测试函数的名称必须要以test开头 。
pytest默认的就按照上面的三条规则来执行案例,当然我们可以自定义运行规则,这个我们后面在讲,这个不重要,看一个最简单的例子 。
import osimport 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"])
2、介绍pytest的前置条件和后置条件,类似unittest的testfixture(测试固件) 。
如果同学们之前用过unittest测试框架,对测试固件这个这个名词就不会陌生了,如果不清楚,可以看下之前我写的unittest测试框架的博客(https://www.cnblogs.com/bainianminguo/p/11616526.html) 。
pytest框架的测试固件有两种,一种函数级别的,一种是类级别,执行的顺序如下 。
a、执行类的前置条件 。
b、执行函数的前置条件 。
c、执行函数的后置条件 。
d、执行类的后置条件 。
使用也非常简单,当时函数的命名一定要和我下面的备注保持完全一致 。
# pytest的前置和后置条件 # 1、函数级别 setup teardown# 运行于测试方法的开始和结束# 运行一个测试用例,会运行一次setup和teardown # 2、类级 setup_class teardown_class# 运行于测试类的开始和结束# 一个测试类只运行一次setup_class teardown_class
1、函数式的案例--函数级别的前置条件&后置条件 。
import osimport 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("函数级别的后置")
执行结果如下 。
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"])
执行结果如下 。
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"])
结果如下 。
3、介绍如何修改pytest的配置文件 。
我们在博客的第一部分介绍了pytest框架的运行规则,这里我们可以修改pytest的配置文件,改变框架运行规则 。
首先我们要在案例的目录下创建一个pytest.ini的配置文件 。
内容如下 。
# 创建pytest.ini文件# [pytest]# addopts=-s#这个先这样写,这个主要是执行参数 # testpaths = testcase# 只执行这个目录下的文件## python_files = test_*.py#执行的文件的名字 # python_classes = Test_*#执行类的名字 # python_functions = test_*# 执行函数的名字
配置文件截图 。
通过上面的步骤,我们就可以改变pytest的运行规则 。
4、介绍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"])
5、介绍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")
6、介绍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"\.... 。
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"])
实现的效果如下 。
7、介绍pyest的常用第三方插件 。
1、美化pytest的输出报告插件 。
# pip install pytest-html # 用来美化输出报告的插件# 只需要在配置文件中加这个配置即可## addopts=-s --html=report.html
效果 。
2、失败案例重试插件,下面的示例实现的就是失败重启3,失败后间隔2s在进行重试 。
# pip install pytest-rerunfailures# 失败重试的第三方插件# 只需要在配置文件中加这个配置即# --reruns 3 --reruns-delay 2
至此,pytest的框架基本使用已经讲解清楚,小伙伴们还有不清楚的吗?欢迎大家来沟通!!! 。
到此这篇关于python单元测试框架pytest的使用示例的文章就介绍到这了,更多相关python单元测试框架pytest内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/bainianminguo/p/13773717.html 。
最后此篇关于python单元测试框架pytest的使用示例的文章就讲到这里了,如果你想了解更多关于python单元测试框架pytest的使用示例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我试图要求 test/unit 的新版本(即不是与 ruby 捆绑的版本) .根据 instructions我用 gem i test-unit 安装它.但是现在当我需要 test/unit我似乎
简短版本是: 我有一个 systemd 单元,我想在调用时检查脚本的返回代码: systemctl status service.service 长版本:我有一个 lsb init 脚本正是这样做的,
我正在使用反射动态创建一个类的实例,这工作正常,除非尝试通过单元测试执行此操作 - 我使用的是 MS 测试框架。 我收到熟悉的错误:“无法加载文件或程序集‘Assy’或其依赖项之一。系统找不到指定的文
我想知道测试网站“界面功能”的最佳实践是什么。 我对哪些方法可用于测试界面和动态生成的内容感兴趣。特别是,我很难弄清楚是否可以为需要用户交互的操作创建自动化测试,或者这是否只是浪费时间,我应该让一些
我有一个简单的 Python 服务,其中有一个无限执行某些操作的循环。在各种信号上,sys.exit(0) 被调用,这导致 SystemExit 被引发,然后如果可以的话应该进行一些清理。 在测试中,
我正在使用 OpenCV 2.4.2 这是 OpenCV 文档中的引文 C++: void HoughLinesP(InputArray image, OutputArray lines, doubl
忙于 C# 中的自动化测试用例,我们需要在每次测试后恢复数据库快照。问题是,当运行多个测试时它会失败,因为“其他用户正在使用数据库时无法更改数据库状态。” 我们使用 SqlConnection.Cle
我阅读了 C# 规范并用谷歌搜索了它,但一无所获。 我 99% 肯定 C# 中没有像单元命名空间指令这样的功能,但问题是:为什么?是否有惯用或技术原因? 这很方便,尤其是当我们的大部分文件都由单个命名
我目前正在尝试向我的应用程序(一个非常老的项目......评论说 iOS 2.0)添加单元测试(精确的应用程序测试)并且总是偶然发现 undefined symbols for architectur
我正在使用Delphi 7,并且有一个新单元要在我的项目中使用。我已经编译了新的。当我尝试通过将其添加到uses子句在项目中使用此单元时,出现错误,提示未找到.dcu文件。我还尝试将文件的完整路径放在
场景:我需要编写一个复杂的nHibernate查询,该查询将返回预计的DTO,但是我想使用TDD方法。该方法如下所示: public PrintDTO GetUsersForPrinting(int
您可以通过运行以下命令在事件 html 设置中显示 Jupyter 笔记本: $ jupyter nbconvert untitled.ipynb --to slides --post serve 有
如何在一个网站上拥有多个 AdSense 单元? Google 提供的唯一代码是按单位计算的。 (adsbygoogle = window.adsbygoogle || []).push({})
我刚刚开始为大量代码编写测试。有很多类依赖于文件系统,即读取 CSV 文件、读/写配置文件等。 当前测试文件存储在项目(这是一个 Maven2 项目)的 test 目录中,但由于多种原因该目录并不总是
我对 TDD 还很陌生,在单元测试方面也不是很老练,所以才有这个问题。我有这个用 PHP 编写的遗留函数 function foo(){ x = bar(); y = baz();
我创建了一个程序,在 Swing 窗口的一侧显示结果过滤选项,但默认情况下它们水平相邻显示,这浪费了我在 BorderLayout 的西侧分配的空间。我可以在构造函数或添加语句中传递任何内容来将它们堆
标题不好的借口:如果有人能更好地描述它,请做。 我有一个 WeakList类,它“基本上”是一个 List> (虽然不是字面意义上的派生自列表,但它应该对用户完全透明)。 现在的基本思想是“如果引用的
我正在尝试在 UITableView 上添加两个原型(prototype)单元。但是,我不知道如何验证是否能够为每个原型(prototype)“返回”正确的单元格。你们能帮我一下吗? func ta
我正在使用 CloudKit 作为数据库创建一个简单的待办事项列表应用程序。目前我可以添加和删除对象,但对编辑对象感到困惑。 编辑项目 Controller protocol EditItemCont
我正在针对以下任务训练 RNN:给定一个包含 30 个单词的序列,然后将该序列分类为二进制类。 在我的网络中拥有超过 30 个单元(LSTM、GRU 或普通 RNN)有好处吗?我在网上看到过很多例子,
我是一名优秀的程序员,十分优秀!