pytest运行参数与ini配置
pytest测试用例的运行方式
主函数模式
(1)运行所有:pytest.main()
(2)指定模块:pytest.main(['-vs','test_demo.py'])
(3)指定目录:pytest.main(['-vs','./test_case'])
(4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组
成。
如:pytest.main(['-vs', './test_case/test_demo.py::Test_case'])
pytest.main(['-vs', './test_case/test_demo.py::Test_case::test_02'])
命令行模式
(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:表示输出调试信息,包括print打印的信息
-v:显示更详细的信息
-vs:这两个参数一起用
-n:支持多线程或者分布式运行测试用例 如:pytest -vs ./testcase/test_login.py -n 2
--reruns NUM:失败用例重跑
-x:表示只要要一个用例报错,那么测试停止。
--maxfail=2 出现两个用例失败就停止。
-k:根据测试用例的部分字符串指定测试用例。如:pytest -vs ./testcase -k "ao"
--html ./report/report.html:生成html的测试报告。
通过读取pytest.ini全局配置文件运行。
pytest.ini文件是pytest单元测试框架的核心配置文件。
1.位置:一般放在项目的根目录。
2.编码:必须是ANSI。
3.作用:改变pytest默认的行为。
4.运行的规则;不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件。
[pytest] addopts = -vs -n 2 #命令行的参数,用空格分隔 testpaths =./test_case #测试用例的路径
python_files = test_*.py #模块名的规则
python_classes = Test* #类名的规则
python_functions = test #方法名的规则
markers = # 标记,用于指定用例执行,使用装饰器@pytest.mark.标记 配合使用,需要在addopts中使用【-m smoke】才能生效,其中smoke是标记名,可以替换
smoke:冒烟用例 # 中文可有可无,标记字段说明
usermanage:用户管理模块
productmanage:商品管理模块
运行结果
pycharm配置pytest运行用例
进入【Run--Edit Configuration】配置
选择pytest编译器,点击运行,可得到结果