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")可以只运行标记的类和方法。

相关推荐
编程猪猪侠1 小时前
解决yarn install 报错 error \node_modules\electron: Command failed.
前端·javascript·electron
来自星星的坤6 小时前
Vue 3中如何封装API请求:提升开发效率的最佳实践
前端·javascript·vue.js
vvilkim8 小时前
全面解析React内存泄漏:原因、解决方案与最佳实践
前端·javascript·react.js
vvilkim8 小时前
React批处理(Batching)更新机制深度解析
前端·javascript·react.js
Bayi·8 小时前
前端面试场景题
开发语言·前端·javascript
程序猿熊跃晖8 小时前
Vue中如何优雅地处理 `<el-dialog>` 的关闭事件
前端·javascript·vue.js
进取星辰8 小时前
12、高阶组件:魔法增幅器——React 19 HOC模式
前端·javascript·react.js
拉不动的猪9 小时前
前端低代码开发
前端·javascript·面试
程序员张39 小时前
Vue3集成sass
前端·css·sass
夜跑者9 小时前
axios 在请求拦截器中设置Content-Type无效问题
前端