unittest 和 pytest 的区别

一、用例编写规则

1.unittest 提供了 test cases、test suites、test fixtures、test runner 相关的类,让测试更加明确、方便、可控。使用 unittest 编写用例,必须遵守以下规则:

(1)测试文件必须先 import unittest

(2)测试类必须继承 unittest.TestCase

(3)测试方法必须以"test_"开头

(4)测试类必须要有 unittest.main()方法

2.pytest 是 python 的第三方测试框架,是基于 unittest 的扩展框架,比 unittest 更简洁,更高效。使用 pytest 编写用例,必须遵守以下规则:

(1)测试文件名必须以"test_"开头或者"test"结尾(如:test_ab.py)
(2)测试方法必须以"test
"开头。

(3)测试类命名以"Test"开头。

二、用例前置和后置

1.unittest 提供了 setUp/tearDown,每个用例运行前、结束后运行一次。setUpClass 和 tearDownClass,用例执行前、结束后,只运行一次

2.pytest 提供了模块级、函数级、类级、方法级的 setup/teardown,比 unittest 的 setUp/tearDown 更灵活。

三、断言

1.unittest 提供了 assertEqual、assertIn、assertTrue、assertFalse。

2.pytest 直接使用 assert 表达式。

四、报告

1.unittest 使用 HTMLTestRunnerNew 库。

2.pytest 有 pytest-HTML、allure 插件。

五、失败重跑

1.unittest 无此功能。

2.pytest 支持用例执行失败重跑,pytest-rerunfailures 插件。

六、参数化

1.unittest 需依赖 ddt 库,

2.pytest 直接使用@pytest.mark.parametrize 装饰器。

七、用例分类执行

1、unittest 默认执行全部用例,也可以通过加载 testsuit,执行部分用例。

2、pytest 可以通过@pytest.mark 来标记类和方法,pytest.main 加入参数("-m")可以只运行标记的类和方法。

相关推荐
掘金安东尼7 小时前
纯 CSS 实现弹性文字效果
前端·css
牛奶7 小时前
Vue 基础理论 & API 使用
前端·vue.js·面试
牛奶7 小时前
Vue 底层原理 & 新特性
前端·vue.js·面试
anOnion8 小时前
构建无障碍组件之Radio group pattern
前端·html·交互设计
pe7er8 小时前
状态提升:前端开发中的状态管理的设计思想
前端·vue.js·react.js
SoaringHeart9 小时前
Flutter调试组件:打印任意组件尺寸位置信息 NRenderBox
前端·flutter
晚风予星9 小时前
Ant Design Token Lens 迎来了全面升级!支持在 .tsx 或 .ts 文件中直接使用 Design Token
前端·react.js·visual studio code
sunny_10 小时前
⚡️ vite-plugin-oxc:从 Babel 到 Oxc,我为 Vite 写了一个高性能编译插件
前端·webpack·架构
GIS之路10 小时前
ArcPy 开发环境搭建
前端
林小帅11 小时前
【笔记】OpenClaw 架构浅析
前端·agent