unittest框架和pytest框架区别及示例
类型 | unittest框架 | pytest框架 | unittest框架示例 | pytest框架示例 |
---|---|---|---|---|
安装 | python内置的一个单元测试框架,标准库,不需要安装 | 第三方单元测试库,需要安装 | 使用时直接引用 import unittest | 安装命令:pip3 install pytest,使用时直接引用import pytest |
用例编写规范 | 1. 测试类必须继承 unittest.TestCase,2. 测试方法必须test开头命名 | 1. 测试模块以 test_ 开头命名如:test_login.py,或以 _test 结尾,2. 测试类必须以Test开头命名,且测试类中不能有 init 方法,3. 测试方法/测试函数:必须以test开头 | ||
执行方式 | 1. unittest和pytest框架都可以在文件里和终端执行, | 2. unittest和pytest执行方式并不依赖终端和文件内的命令,后期会单独创建一个main执行入口文件来执行(这里了解即可,先当测试使用) | 1. 文件内执行:pytest.main([‘-s’,‘-v’]),2. 终端执行:pytest -s -v | |
执行顺序 | ||||
筛选用例 | 可以通过筛选函数名、类名、模块名执行 | |||
前置和后置 | 提供了setUp/tearDown,每个用例运行前、结束后运行一次。setUpClass和tearDownClass,所有用例执行前、结束后,只运行一次 | |||
收集用例 | 使用unittest.TestSuite()套件收集测试用例,再通过TestLoader()加载器:可以加载类,加载模块名执行 | 创建 py 文件命名以 test_开头或者_test 结尾文件自动收集用例,例如: test_login.py login_test.py | ||
断言 | ||||
参数化 | 直接使用@pytest.mark.parametrize装饰器,例如:@pytest.mark.parametrize(“case”,test_data) #case :变量名 item:测试数据 test_data | |||
测试报告 | 1. 使用unittest自带的测试报告格式 2. 使用HTMLTestRunnerNew库,需要额外安装 | |||
重运行机制 | 1. unittest不支持,2. 可以参考unittestreport扩展库支持重运行机制,安装命令: pip install unittestreport | 通过插件rerunfailures支持重运行机制,安装命令:pip install pytest-rerunfailures,例如(指定标签失败用例–运行2次间隔为5秒后):pytest -m smoke --reruns 2 --reruns-delay 5 | ||
运行 | 一般都会单独写一个main执行入口文件,有两种运行 1. 使用unittest自带的runner,2. 结合HTMLTestRunnerNew插件运行 | 通过main入口文件执行命令,也可以通过终端命令执行 | ||
插件 | 无 | 比unittest插件相对多很多,目前有600+,比如allure插件 |