安装 |
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插件 |
|
|