pytest单元测试框架(入门篇)
单元测试有
java: junit/testing
python:unittest/pytest
单元测试框架 1.测试发现 2.测试执行 3.测试判断 4.测试报告
一、pytest简介
1.pytest是一个非常成熟的python的单元框架,比unittest更灵活。
2.pytest可以和selenium,requests,appium结合实现web自动化,接口自动化,app自
动化。
3.pytest可以实现测试用例的跳过以及reruns失败用例重试。
4.pytest可以和allure生成非常美观的测试报告。
5.pytest可以和Jenkins持续集成。
6.pytest有很多非常强大的插件,并且这些插件能够实现很多的实用的操作。
pytest
pytest-xdist # 测试用例分布式执行。多CPU分发。 pytest-ordering # 用于改变测试用例的执行顺序(从上到下) pytest-rerunfailures # 用例失败后重跑 pytest-html # (生成html格式的自动化测试报告) allure-pytest # 用于生成美观的测试报告。
1.Pytest插件安装
一个个安装太麻烦,统一放到requirements.txt中,用pip install -r requirements.txt进行安装
pip install -r requirements.txt
步骤:在项目名中右键NEW--File,命名为requirements.txt,输入上面指令,通过Terminal输入pip install -r requirements.txt,回车进行安装
验证是否安装成功:pytest --version
以上安装方法只适用于本项目,如果要全部使用,则通过cmd进行安装(如果升级安装,则在 install 后面加 -U即可)
pip install pytest pip install pytest-xdist pip install pytest-ordering pip install pytest-rerunfailures pip install pytest-html pip install allure-pytest
二、使用Pytest,默认的测试用例规则
1.模块名必须以test_开头或者_test结尾
2.测试类必须以Test开头,并且不能有init方法。
3.测试方法必须以test开头
三、Pytest测试用例运行模式
1.主函数模式
(1)运行所有:pytest.main()
(2)指定模块:pytest.main(['-vs','test_login.py'])
(3)指定目录:pytest.main(['-vs','./interface_testcase'])
(4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成。
nodeid指定用例运行
指定方法
if __name__ == '__main__': pytest.main(['-vs', './test_cases/test_01.py::test_funtion']) # 通过nodeid指定用例运行
指定类里面的方法
if __name__ == '__main__': pytest.main(['-vs', './test_cases/test_01.py::TestLogin::test_001'])
=================================================================================
如果要输出调试信息
pytest.main('-s')
-s:表示输出调试信息,包括print打印的信息 -v:结果显示更详细的信息,比如模块名,类名,方法名,测试结果 -vs:这两个参数一起用(显示详细信息,和打印信息) -n:支持多线程或者分布式运行测试用例。 如:pytest -vs ./testcase/test_login.py -n 2 --reruns NUM:失败用例重跑 -x:表示只要要一个用例报错,那么测试停止。 --maxfail=2 出现两个用例失败就停止。 -k:根据测试用例的部分字符串(函数名,方法名等)指定测试用例。
1) -vs参数
2) -n 测试用例并行运行
先来看没有并行的情况
由下图可以看出,没有并行时,花费了 10.05S
下面来看 - n 并行运行的情况(2个测试用例,就是两个线程),测试时间是6.90S ,可以看出测试时间缩短了
if __name__ == '__main__': pytest.main(['-vs', './test_cases', '-n=2'])
3) --reruns NUM 失败用例重跑
if __name__ == '__main__': pytest.main(['-vs', './test_cases', '--reruns=2'])
4) -k:根据测试用例的部分字符串(函数名,方法名等)指定测试用例。
if __name__ == '__main__': pytest.main(['-vs', './test_cases/test_01.py', '-k', 'may'])
运行结果可看出,只运行了带may的测试用例
2.命令行模式
,运行有,在Terminal输入
(1)运行所有:pytest
(2)指定模块:pytest -vs test_login.py
(3)指定目录:pytest -vs ./interface_testcase
(4)指定目录:pytest -vs ./interface_testcase/test_interface.py::test_04_func
参数详解:-s,-v,-vs,-v,--reruns,-x,--maxfail,-k
-s:表示输出调试信息,包括print打印的信息
-v:显示更详细的信息,模块名,类名,方法名,测试结果
-vs:这两个参数一起用(显示详细信息和打印信息)
-n:支持多线程或者分布式运行测试用例。
pytest -vs ./test_cases/test_01.py -n 2
--reruns NUM:失败用例重跑
pytest -vs ./test_cases/test --reruns 2
-x:表示只要要一个用例报错,那么测试停止
--maxfail=2 出现两个用例失败就停止。
pytest -vs ./test_cases/test --maxfail 2
-k:根据测试用例的部分字符串(函数名,方法名等)指定测试用例。
pytest -vs ./test_cases/test_01.py -k "may"
--html ./report/report.html:生成html的测试报告。(查看本网页最尾部)
3.通过读取pytest.ini全局配置文件运行
(配置好这个文件后,其他正常运行即可。该配置优先级高于主函数和命令行的配置)
pytest.ini这个文件它是pytest单元测试框架的核心配置文件。
1.位置:一般放在项目的根目录,名称 pytest.ini
2.编码:必须是ANSI,可以使用notpad++修改编码格式。
步骤一、 pytest_ini文件复制到电脑桌面,用notpad++,Encoding-->Convert to ANSI,保存后复制该文件
步骤二、项目右键-->Paste-->OK-->Overwrite
[pytest] addopts = -vs testpaths = ./test_cases python_files = test_*.py python_classes = Test* python_functions = test
3.作用:改变pytest默认的行为。
4.运行的规则;不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件。
addopts = -vs #命令行的参数,用空格分隔
testpaths = ./testcase #测试用例的路径
python_files = test_*.py #模块名的规则
python_classes = Test* #类名的规则
python_functions = test #方法名的规则
四、pytest执行测试用例的顺序@pytest.mark.run(order=num)
unittest:ascII的大小来绝对的执行的顺序
pytest:默认从上到下
改变默认的执行顺序:使用mark标记。
@pytest.mark.run(order=3)
import time import pytest def test_funtion_may(): print("函数") class TestLogin: def test_001(self): time.sleep(5) print("pytest输出") @pytest.mark.run(order=2) def test_002_may(self): assert 2 == 1 def test_003(self): print("输出May") @pytest.mark.run(order=1) def test_004(self): print("花花")
运行结果如下
五、如何分组执行(冒烟用例)mark自定义
smoke:冒烟用例,分布在各个模块里面
pytest -m "smoke"
pytest -m "smoke or usermanage"
pytest -m "not smoke"
markets =
smoke:冒烟用例
usermanage:用户管理模块
smoke和usermanage是自定义的,根据自己需要
在用例前面增加
@pytest.mark.smoke
@pytest.mark.usermanage
test_02.py
import time import pytest class TestLog: def test_003(self): time.sleep(5) print("测试用例并行运行") @pytest.mark.smoke def test_chen(self): print("huayu") @pytest.mark.usermanage def test_user(self): print("用户管理")
运行pytest -m "smoke or usermanage"
六、pytest跳过测试用例@pytest.mark.skip(reason="不想运行该用例")
(1)无条件跳过
@pytest.mark.skip(reason="不想运行该用例") def test_chen(self): print("huayu")
(2)有条件跳过
age = 18 @pytest.mark.usermanage @pytest.mark.skipif(age>=18, reason="年龄大于18跳过") def test_user(self): print("用户管理")
七、生成报告
在配置文件中配置 pytest.ini 的 addopts
[pytest] addopts = -vs --html ./report/report.html testpaths = ./test_cases python_files = test_02.py python_classes = Test* python_functions = test markets = smoke:冒烟用例 usermanage:用户管理模块
运行后,可查看报告