pytest-html生成html格式的自动化测试报告
pytest-xdist测试用例分布式执行,多cpu分发
pytest- ordering用于改变测试用例的执行顺序
pytest-rerunfailures用例失败后重跑
allure-pytest用于生成美观的测试报告
一、使用pytest,默认的测试用例规则以及基础应用
1、模块名必须以test_开头或者_test结尾
2、测试类必须以Test开头且不能有init方法
3、测试方法必须以test开头
二、pytest测试用例运行方式
1、主函数模式
a.运行所有:pytest.main()
b.指定模块:pytest.main(['-vs','test_login.py'])
c.指定目录:pytest.main(['-vs','./interface_testcase.py'])
d.通过nodeid指定用例运行:nodeid由模块名、分隔符、类名、方法名、函数名组成
pytest.main(['-vs','./interface_testcase/test_interface.py::Testinterface::test_03_func'])
2、命令行模式
a.运行所有 pytest
b.指定模块 pytest -vs test_login.py
c.指定目录 pytest -vs ./interface_testcase.py
d.指定目录 pytest -vs ./interface_testcase/test_interface.py::Testinterface::test_03_func
参数详解:
-s 输出调试信息,包括print的打印信息
-v 显示更详细的信息
-vs 两个参数一起显示
-n 支持多线程或者分布式运行测试用例,如:pytest -vs ./interface_testcase.py -n 2
-- reruns 数字:失败用例重跑多少次
-x:只要一个用例报错,那么测试停止
--maxfall=2:出现两个用例失败就停止
-k:根据测试用例的部分字符串指定测试用例,如:pytest -vs ./interface_testcase.py -k “ao”执行含ao的测试用例方法
3、通过读取pytest.ini配置文件运行
放在项目的根目录,核心配置文件,编码:必须是ANSI,可以使用nodepad++修改格式。作用是:改变文件名或者类名等必须以test开头或结尾的默认行为,可重新自定义。
[pytest]
addopts = -vs #命令行的参数,用空格分隔
testpaths =./testcase #测试用例的路径
python_files = test_*.py #模块名规则
python_classes = Test* #类名规则
python_functions = test_ #方法名规则
三、pytest测试用例执行的顺序
unittest根据ascii码的顺序执行
pytest默认从上到下,改变默认的顺序,使用mark装饰器,先安装包pytest- ordering。
方法名上写装饰器:@pytest.mark.run(order=3)
四、如何分组执行(冒烟、分模块执行、分模块、分接口)
smoke:冒烟用例,分布在各个模块里面
pytest -m “smoke”
pytest -m “smoke or usermanage or productmanage"
方法名上写装饰器:@pytest.mark.smoke
配置文件pytest.init中定义:
markers=
smoke
usermanage
productmanage
五、pytest跳过测试用例
1、无条件跳过
@pytest.mark.skip(reason="微微太漂亮").
2、有条件跳过
@pytest.mark.skipif(age>=18,reason="已成年") # reason固定参数,age自定义参数