news 2026/4/18 3:43:40

5分钟Pytest快速入门

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
5分钟Pytest快速入门

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

Pytest的入门操作使用

Pytest特点

  1. 非常容易上手,入门简单,文档丰富,文档中有很多实例可以参考

  2. 能够支持简单的单元测试和复杂的功能测试

  3. 支持参数化

  4. 执行测试过程中可以将某些测试跳过(skip),或者对某些预期失败的case标记成失败

  5. 支持重复执行(rerun)失败的 case

  6. 支持运行由 nose, unittest 编写的测试 case

  7. 可生成html报告

  8. 方便的和持续集成工具jenkins集成

  9. 可支持执行部分用例

  10. 具有很多第三方插件,并且可以自定义扩展

安装

直接执行 如下命令即可安装pytest

pip install pytest

我们还需要产生测试报表,所以要安装一个第三方插件pytest-html,执行如下命令安装

pip install pytest-html
def func(x): return x + 3 def test_answer(): assert func(3) == 6 class TestClass: def test_01(self): print('\n用例01') assert 1 == 1 def test_02(self): print('\n用例02') assert 2 == 2 def test_03(self): print('\n用例03') assert 3 == 2

然后,cmd进入当前文件目录,直接执行

pytest
PS D:\Lemon\py45\webatuotest\pytest_learn> pytest .\test_learn01.py ========================================================== test session starts ========================================================== platform win32 -- Python 3.9.7, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 rootdir: D:\Lemon\py45\webatuotest\pytest_learn plugins: allure-pytest-2.9.43, anyio-3.3.2, html-3.1.1, metadata-1.11.0 collected 4 items test_learn01.py ...F [100%] =============================================================== FAILURES ================================================================ ___________________________________________________________ TestClass.test_03 ___________________________________________________________ self = <test_learn01.TestClass object at 0x0000023FFB6743D0> def test_03(self): print('\n用例03') > assert 3 == 2 E assert 3 == 2 test_learn01.py:27: AssertionError --------------------------------------------------------- Captured stdout call ---------------------------------------------------------- 用例03 ======================================================== short test summary info ======================================================== FAILED test_learn01.py::TestClass::test_03 - assert 3 == 2 ====================================================== 1 failed, 3 passed in 0.21s ====================================================== PS D:\Lemon\py45\webatuotest\pytest_learn>

注意:

  • 如果只执行pytest,会查找当前目录及其子目录下以test_*.py 或 *_test.py文件,找到文件后,在文件中找到以 test 开头函数并执行

  • 如果只想执行某个文件,可以pytest start.py

  • 加上-q,就是显示简单的结果:pytest -q start.py

  • 如果我们希望 显示测试代码中print的内容,因为这些打印语句在调试代码时很有用,可以加上命令行参数 -s

    如下

    pytest -s
  • 如果我们希望得到更详细的执行信息,包括每个测试类、测试函数的名字,可以加上参数 -v,这个参数可以和 -s 合并为 -sv

    如下

    pytest -sv
  • 为了防止pytest到其他目录中找测试用例项,执行测试时,我们可以在命令行加上目标目录 cases ,就是这样

pytest cases
pytest运行方式 测试类主函数模式 # test_abc.py import pytest # 引入pytest包 def test_a(): # test开头的测试函数 print("------->test_a") assert 1 # 断言成功 def test_b(): print("------->test_b") assert 0 # 断言失败 if __name__ == '__main__': # pytest.main("-s test_abc.py") 早期版本是这样的执行的 pytest.main(["-s", "test_abc.py"]) # 调用pytest的main函数执行测试

命令行模式运行

# pytest 文件路径/测试文件名pytest ./test_abc.py

Pytest用例的设计原则

Pytest写用例时候,一定要按照下面的规则去写,否则不符合规则的测试用例是不会执行的

  • 文件名以test_*.py文件和*_test.py

  • 以 test_ 开头的函数

  • 以 Test 开头的类,不能包含__init__ 方法

  • 所有的包 package 必须要有__init__.py文件

Pytest之并发执行

在Pytest测试框架中提供了pytest-xdist可以并发执行测试用例,来提升测试用例的执行速度。通常的情况下,测试用例的执行都是依据一定的规则来按顺序进行执行,这样的结果是每次执行的时候有的资源就只能被一个测试用例占用,而达不到测试用例执行的时候资源的共享,插件pytest-xdist插件可以很好的解决这个问题,一方面资源达到共享,基于第一点的考虑,也就达到了第二点的提升了测试执行的效率。

  • 安装pytest-xdist插件 pip install pytest-xdist

  • 使用 pytest -n auto 默认自动检查系统cpu个数,然后进行并发

  • 也可以指定并发数 pytest -n 2 即并发数2执行

pytest的重复执行

安装:pip3 install pytest-repeat

命令行方式

使用–count命令行选项来指定您要运行一个或多个测试的次数:

pytest --count = 10 test.py

代码方式

如果要在代码中将测试标记为重复多次,则可以使用

# @pytest.mark.repeat(count)装饰器: import pytest @pytest.mark.repeat(3) def test_example(): print("执行成功")

重复测试直到失败

有时候,功能模块不稳定,会存在一些错误,可以将 -x 与 pytest-repeat 一起用,强制运行器在第一次测试失败时停止

py.test --count=1000 -x test.py

repeat-scope的使用

命令行参数
作用:能够覆盖默认的测试用例执行顺序,相似fixture的scope参数

  • function:默认,范围针对每一个用例重复执行,再执行下一个用例

  • class:以class为用例集合单位,重复执行class里面的用例,再执行下一个

pytest -s --count=2 --repeat-scope=class test_Class.py
  • module:以模块为单位,重复执行模块里面的用例,再执行下一个

pytest -s --count=2 --repeat-scope=moudle test_Class.py
  • session:重复整个测试会话,即全部测试用例的执行一次,而后再执行第二次

产生报告

前面在安装pytest,我们也安装了pytest-html插件,这个插件就是用来产生测试报告的。

要产生报告,在命令行加上 参数--html=report.html --self-contained-html,如下

pytest cases --html=report.html --self-contained-html

这样就会产生名为report.html的测试报告文件,可以在浏览器中打开

写在最后

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/23 3:07:11

污水处理DCS数据采集组态监控系统方案

某污水处理厂采用DCS系统对污水处理流程进行集中监控与控制&#xff0c;具备手动、自动、维护等多种运行模式&#xff0c;并在中控室实现工艺参数的实时展示与设备状态管理。为进一步提升管理效率与智能化水平&#xff0c;现需对现有系统进行数字化升级&#xff0c;将污水处理关…

作者头像 李华
网站建设 2026/4/17 6:03:16

基于贾子智慧理论体系的中国 AI 发展与竞争国家战略(2025-2035)

智慧主导智能&#xff1a;基于贾子智慧理论的中国AI发展与竞争国家战略&#xff08;2025‑2035&#xff09; 摘要 本战略以贾子智慧“四大支柱五五三三定律”为框架&#xff0c;确立“智慧主导智能、可控优于领先”的核心原则&#xff0c;旨在构建区别于美国技术霸权的新范式。…

作者头像 李华
网站建设 2026/4/17 21:07:02

基于Simulink的双模式MPPT(快速追踪+稳态优化)仿真

目录 手把手教你学Simulink--基础MPPT控制场景实例&#xff1a;基于Simulink的双模式MPPT&#xff08;快速追踪稳态优化&#xff09;仿真 一、引言&#xff1a;为什么需要双模式MPPT&#xff1f;——光伏系统“效率与响应”的平衡术 二、核心原理&#xff1a;双模式MPPT的“切…

作者头像 李华
网站建设 2026/4/17 13:57:24

【极客日常】快速上手复杂后端项目开发的经验

去年年底一段时间&#xff0c;笔者参与了组织内部智能化平台项目研发攻坚&#xff0c;虽然主攻平台工程部分&#xff0c;但多少也了解了下目前AIGC可以应用到的一些业务场景&#xff0c;以及技术实践、项目管理的一些事情。在先前的文章里头&#xff0c;有浅要描述下AIGCWeb类项…

作者头像 李华
网站建设 2026/4/3 4:38:41

2026必备!10个AI论文网站,继续教育学生轻松搞定毕业论文!

2026必备&#xff01;10个AI论文网站&#xff0c;继续教育学生轻松搞定毕业论文&#xff01; AI 工具让论文写作更高效 在当前的学术环境中&#xff0c;继续教育学生面临着越来越高的论文写作要求。无论是学位论文还是科研项目报告&#xff0c;都需要高质量的内容支撑。而随着人…

作者头像 李华