一、简介
1.pytest是一个非常成熟的Python的单元框架,比unittest更灵活;
2.pytest可以和selenium、requests、appium结合实现web自动化、接口自动化、app自动化;
3.pytest可以实现测试用例的跳过以及reruns失败用例重试;
4.pytest可以和allure生成好看的测试报告;
5.pytest可以和Jenkins配置持续集成;
6.pytest有很多强大的插件,足以支撑我们的常用操作,如下:
pytest-xdist 分布式执行case,多CPU分发
pytest-ordering 改变case的执行顺序
pytest-rerunfailures 失败case重跑
pytest-html 生成html格式的测试报告
allure-pytest 用于生成好看的测试报告
注意:以上插件都需要手动安装,可以放到requirements.txt中,通过pip install -r requirements.txt 统一安装,该方式安装的只针对当前项目
二、pytest默认规则
1.模块名必须以test_开头或者_test结尾
2.测试类必须以Test开头,并且不能有init方法
3.测试方法必须以test开头
注意:这些都是默认规则,如果不想用默认规则,需要重新定义配置参数对应规则即可;
三、pytest case 运行方式
~参数详解
-s 表示输出调试信息,包括print打印的信息
-v显示更详细的信息
-vs两个参数一起使用
-n支持多线程或者分布式运行测试用例
-reruns num 失败case重跑
-x表示只要有一个case报错就停止运行
-maxfail=2 最大失败数,出现两个失败用例就停止
-k根据case的部分字符串选中case
-html 生成html格式的测试报告
1.主函数模式
1.1运行所有:pytest.main()
1.2指定模块:pytest.main(['-vs','test_login.py'])
1.3指定目录:pytest.main(['-vs','./interface_testcase'])
1.4通过nodeid指定用例运行:
pytest.main(['-vs','./interface_testcase/test_login.py::test_01_func'])
2.命令行模式
2.1运行所有 pytest
2.2指定模块 pytest -vs test_login.py
2.3指定目录 pytest -vs ./interface_testcase
2.4指定方法pytest -vs ./interface_testcase/test_login.py::test_01_func
3.通过读取pytest.ini全局配置文件运行(最常用的方式)
pytest.ini这个文件是pytest单元测试框架的核心配置文件(我们说的二的默认规则注意部分的修改参数就是在这个文件里修改)
3.1路径:一般放在项目的根目录
3.2编码格式:必须是ANSI,可以使用编辑器(sublime text)修改
3.3作用:改变pytest默认行为,按照文件内容执行
3.4运行规则:不管是主函数还是命令行模式运行,都会读取这个配置文件,常见的ini内容如下:
[pytest]
addopts=-vs #命令行参数,用空格分隔
testpaths=./testcase #case路径
python_files=test_*.py #模块名规则
python_classes=Test* #类名的规则
python_functions=test # 方法名规则
markers=
smoke:冒烟用例
interface:接口用例
web:网页用例
order:订单管理模块
user:用户模块
四、pytest执行case的顺序
默认是从上到下
改变默认执行顺序:使用mark标记
@pytest.mark.run(order=3)
五、分组执行(冒烟、功能模块、类型(接口&web))
smoke:冒烟用例,分布在各个模块里
先在用例里标记,然后-m参数运行即可
@pytest.mark.smoke
pytest -m "smoke"
pytest -m "smoke or user or order"
六、跳过case
1.无条件跳过
@pytest.mark.skip(reason="还没写完")
2.有条件跳过
@pytest.mark.skipif(1==1,reason="符合条件所以跳过")