【Pytest】python单元测试框架pytest简介

【Pytest】python单元测试框架pytest简介1 Pytest 介绍 pytest 是 python 的一种单元测试框架 与 python 自带的 unittest 测试框架类似 但是比 unittest 框架使用起来更简洁 效率更高 根据 pytest 的官方网站介绍 它具有如下特点 非常容易上手 入门简单 文档丰富 文档中有很多实例可以参考能够支持简单的单元测试和复杂的功能测试支持参数化执行测试过程中可以将某些测试跳过 或者对某些预期失败的 case

最新更新请看 《基于Pytest框架的自动化测试开发实践(万字长文入门篇)》

1、Pytest介绍

pytest是python的一种单元测试框架,与python自带的unittest测试框架类似,但是比unittest框架使用起来更简洁,效率更高。根据pytest的官方网站介绍,它具有如下特点:

 

  • 非常容易上手,入门简单,文档丰富,文档中有很多实例可以参考
  • 能够支持简单的单元测试和复杂的功能测试
  • 支持参数化
  • 执行测试过程中可以将某些测试跳过,或者对某些预期失败的case标记成失败
  • 支持重复执行失败的case
  • 支持运行由nose, unittest编写的测试case
  • 具有很多第三方插件,并且可以自定义扩展
  • 方便的和持续集成工具集成
由于网上pytest的中文文档比较少,自己学习过程中,基本上看的就是英文的官方文档,对于不想看英文的同学们,本系列文章希望能够帮大家一马。
 

2、安装pytest

与安装其他的python软件无异,直接使用pip安装。
pip install -U pytest

安装完成后,可以验证安装的版本:

py.test --version

 

3、一个实例

我们可以通过下面的实例,看看使用py.test进行测试是多么简单。
# content of test_sample.py def func(x): return x+1 def test_func(): assert func(3) == 5

这里我们定义了一个被测试函数func,该函数将传递进来的参数加1后返回。我们还定义了一个测试函数test_func用来对func进行测试。test_func中我们使用基本的断言语句assert来对结果进行验证。

下面来运行这个测试:
$ py.test =========================== test session starts ============================ platform linux -- Python 3.4.1 -- py-1.4.27 -- pytest-2.7.1 rootdir: /tmp/doc-exec-101, inifile: collected 1 items test_sample.py F ================================= FAILURES ================================= _______________________________ test_answer ________________________________ def test_answer(): > assert func(3) == 5 E assert 4 == 5 E + where 4 = func(3) test_sample.py:5: AssertionError ========================= 1 failed in 0.01 seconds =========================

执行测试的时候,我们只需要在测试文件test_sample所在的目录下,运行py.test即可。pytest会在当前的目录下,寻找以test开头的文件(即测试文件),找到测试文件之后,进入到测试文件中寻找test_开头的测试函数并执行。

通过上面的测试输出,我们可以看到该测试过程中,一个收集到了一个测试函数,测试结果是失败的(标记为F),并且在FAILURES部分输出了详细的错误信息,帮助我们分析测试原因,我们可以看到”assert func(3) == 5″这条语句出错了,错误的原因是func(3)=4,然后我们断言func(3) 等于 5。
 

4、再一个实例

当需要编写多个测试样例的时候,我们可以将其放到一个测试类当中,如:
# content of test_class.py class TestClass: def test_one(self): x = "this" assert 'h' in x def test_two(self): x = "hello" assert hasattr(x, 'check') 

我们可以通过执行测试文件的方法,执行上面的测试:

$ py.test -q test_class.py .F ================================= FAILURES ================================= ____________________________ TestClass.test_two ____________________________ self = 
   
     def test_two(self): x = "hello" > assert hasattr(x, 'check') E assert hasattr('hello', 'check') test_class.py:8: AssertionError 1 failed, 1 passed in 0.01 seconds 
   

从测试结果中可以看到,该测试共执行了两个测试样例,一个失败一个成功。同样,我们也看到失败样例的详细信息,和执行过程中的中间结果。

 

5、如何编写pytest测试样例

通过上面2个实例,我们发现编写pytest测试样例非常简单,只需要按照下面的规则:
  • 测试文件以test_开头(以_test结尾也可以)
  • 测试类以Test开头,并且不能带有 __init__ 方法
  • 测试函数以test_开头
  • 断言使用基本的assert即可

6、如何执行pytest测试样例

执行测试样例的方法很多种,上面第一个实例是直接执行py.test,第二个实例是传递了测试文件给py.test。其实py.test有好多种方法执行测试:
py.test # run all tests below current dir py.test test_mod.py # run tests in module py.test somepath # run all tests below somepath py.test -k stringexpr # only run tests with names that match the # the "string expression", e.g. "MyClass and not method" # will select TestMyClass.test_something # but not TestMyClass.test_method_simple py.test test_mod.py::test_func # only run tests that match the "node ID", # e.g "test_mod.py::test_func" will select # only test_func in test_mod.py

7、测试报告

pytest可以方便的生成测试报告,即可以生成HTML的测试报告,也可以生成XML格式的测试报告用来与持续集成工具集成。

生成HTML格式报告:

 

py.test --resultlog=path

生成XML格式的报告:

 

 

py.test --junitxml=path

 

8、如何获取帮助信息

py.test --version # shows where pytest was imported from py.test --fixtures # show available builtin function arguments py.test -h | --help # show help on command line and config file options 

9、最佳实践

其实对于测试而言,特别是在持续集成环境中,我们的所有测试最好是在虚拟环境中。这样不同的虚拟环境中的测试不会相互干扰的。
由于我们的实际工作中,在同一个Jekins中,运行了好多种不同项目册的测试,因此,各个测试项目运行在各自的虚拟环境中。
将pytest安装在虚拟环境中:
1、将当前目录创建为虚拟环境
virtualenv . # create a virtualenv directory in the current directory source bin/activate # on unix 

2、在虚拟环境中安装pytest:

pip install pytest

 





 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/229516.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月16日 下午4:32
下一篇 2026年3月16日 下午4:32


相关推荐

  • 2025年AI Agent深度解读:从概念到落地,普通人能抓的机会在哪?

    2025年AI Agent深度解读:从概念到落地,普通人能抓的机会在哪?

    2026年3月15日
    3
  • ubuntu安装pyCUDA

    ubuntu安装pyCUDA0 写在前面安装环境 ubuntu18 04 16 和 18 差不多 但是 18 太爽了 和 python3 具体版本忘了 应该是 3 6 参考链接 参考了验证程序 1 安装 pyCUDA 之前必须安装 CUDA 参考本人上一个博客 2 安装 pyCUDA 首先用 pip3 安装一般服务器会超时 这个时候也可以用清华源或者其他国内源安装 标准命令是 pip3installp

    2026年3月19日
    1
  • 一篇文章彻底弄懂Base64编码原理

    一篇文章彻底弄懂Base64编码原理在互联网中的每一刻 你可能都在享受着 Base64 带来的便捷 但对于 Base64 的基础原理又了解多少 今天这篇博文带领大家了解一下 Base64 的底层实现 Base64 的由来目前 Base64 已经成为网络上常见的传输 8Bit 字节代码的编码方式之一 在做支付系统时 系统之间的报文交互都需要使用 Base64 对明文进行转码 然后再进行签名或加密 之后再进行 或再次 Base64 传输 那么

    2026年3月17日
    8
  • 贝叶斯公式的理解【转】

    贝叶斯公式的理解【转】本文转载自:https://blog.csdn.net/qq_37953276/article/details/79297316作者:知乎用户 链接:https://www.zhihu.com/question/21134457/answer/169523403来源:知乎著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。最近我自己在学习一些关于机器学习的东西,…

    2022年5月5日
    57
  • 【SpringCloud】微服务笔记

    【SpringCloud】微服务笔记集中什么是微服务架构:1597213385700SpringCloud是微服务一站式服务解决方案,微服务全家桶。它是微服务开发的主流技术栈。它采用了名称,而非数字版本号。s方法gCloud和springCloudAlibaba目前是最主流的微服务框架组合。版本选择:选用springboot和springCloud版本有约束,不按照它的约束会有冲突。版本问题本次学习的各种软件的版本:boot使用的是数字作为版本。官网强烈建议升级到2.0以上cloud使用的是字母作为版本,伦

    2022年5月22日
    74
  • int 和 Integer的区别

    int 和 Integer的区别int 和 Integer 的区别分析 intIntegerin 与 Integer 的区别相同值下的 int 和 Integer 的比较结果分析 intint 是 java 的基本数据类型 IntegerInteg 继承了 Object 类 是对象类型 是 int 的包装类 int 与 Integer 的区别值的存储 int 存储在栈中 Integer 对象的引用存储在栈空间中 对象

    2026年3月17日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号