一、pytest简介
- pytest是一个非常成熟的python的单元框架,比unittes更灵活,容易上手。
- pytest可以和selenium,requests,appium结合实现web自动化,接口自动化,APP自动化。
- pytest可以实现测试用例的跳过以及reruns失败用例重试。
- pytest可以和allure生成非常美观的测试报告。
- pytest可以和Jenkins持续集成。
- pytest有很多非常强大的插件,并且这些插件能够实现很多的实用的操作。
pytest
pytest-xdist 测试用例分布式执行。多CPU分发。
pytest-ordering 用于改变测试用例的执行顺序
pytest-rerunfailures 用例失败后重跑
pytest-html 生成html格式的自动化测试报告
allure-pytest 用于生成美观的测试报告
二、使用pytest,默认的测试用例的规则以及基础应用
- 模块名必须以test_开头或者_test结尾。
- 测试类必须以Test开头,并且不能有init方法。
- 测试方法必须以test开头。
三、pytest测用例的运行方式
-
主函数模式
(1) 运行所有: pytest.main()
(2) 指定模块: pytest.main([‘-vs’,‘test_login.py’])
(3) 指定目录: pytest.main([‘-vs’,‘./testcase’])
(4) 通过nodeid指定用例运行 nodeid由模块名,分隔符,类名,方法名,函数名组成。
pytest.main([‘-vs’,‘./testcase/test_login.py::TestInterface::test_03_login’]) -
命令行模式
(1) 运行所有: pytest
(2) 指定模块: pytest -vs test_login.py
(3) 指定目录: pytest -vs ./testcase
(4) 通过nodeid指定用例运行 nodeid由模块名,分隔符,类名,方法名,函数名组成。
pytest -vs ./testcase/test_login.py::TestInterface::test_03_login参数详解: -s: 表示输出调试信息,包括print打印的信息 -v: 显示更详细的信息 -vs: 这2个参数一起用 -n : 分布式运行测试用例 --reruns=num: 失败用例重跑几次 -- maxfail =num: 出现几次失败就停止 -k: 根据测试用例的部分字符串指定测试用例 -v: 类名+方法名 --html :生成html的测试报告 --html ./report/report.html
-
通过读取pytest.ini配置文件运行。
pytest.ini这个文件它是pytest单元测试框架的核心配置文件。
1. 位置:一般放在项目的根目录。
2. 编码:必须是ANSI ,可以使用notpad++修改编码格式。
3. 作用:修改pytest默认的行为。
4. 运行的规则;不管是主函数模式运行,命令行模式运行,都会读取这个配置文件。
【pytest】
addopts = -vs #命令行的参数,用空格分隔。
testpaths = ./testcase #测试用例的路径
python_files = test_*.py #模块名的规则
python_classes = Test* #类名的规则
python_functions = test #方法名的规则
markers =
smoke :“冒烟用例” #分组
四、pytest执行测试用例的顺序
- unittest: ascll的大小来决定执行的顺序
- pytest:默认从上到下
- 改变默认的执行顺序 : 使用 @pytest.mark.run(order=3)
五、如何分组执行
- smoke :冒烟用例,分布在各个模块里面
- pytest -m “smoke”
- pytest -m “smoke or usermanage or productmanage”
六、pytest跳过测试用例
-
无条件跳过
@pytest.mark.skip(reason=“测试跳过1”) -
有条件跳过
@pytest.mark.skipif(age>=18,reason=“测试跳过2”)