pytest是基于单元测试框架unittest的升级版本,相比与unittest支持跨多个文件前置,支持丰富的报告,简练的断言,丰富的插件功能,
pytest分模块运行前置和后置操作分为2种方式,支持经典的setup、setdown和fixture;以及标记参数mark、断言、常用插件
1: 测试文件以 test_ 开头 & 结尾
2: 测试类以 Test 开头,并且不能带有init方法
3: 测试函数&方法以 test开头
4: 断言使用 assert
1.命令行运行
–help
–collect-only 查看可执行用例
test_*.py 执行测试文件
–maxfail=2 最大报错
-m 运行mark标记用例
–setup-show 用例执行的夹具
pytest -k “add” 执行所有测试用例名中含有“add”的用例
pytest - s 打印测试用例中print语句
pytest -v 增加打印细节
pytest - x 一旦发现失败用例,停止运行
pytest -maxfail=2 当测试遇到两条失败,立刻停止运行
pytest -m “标签名” 给测试用例加标签
2.“”“配置文件”“”
pytest.ini
[pytest]
markers=自定义mark:标签名
addopts= 运行时参数(可添加多个命令行参数,空格分隔,所有参数与命令行一致)
3.“”“main方法”“”
import pytest
if name == ‘main’:
pytest.main([“-vs”])
# file_name: test_abc.py
import pytest # 引入pytest包
def test_a(): # test开头的测试函数
print("------->test_a")
assert 1 # 断言成功
def test_b():
print("------->test_b")
assert 0 # 断言失败
if __name__ == '__main__':
pytest.main("-s test_abc.py") # 调用pytest的main函数执行测试
模块级: setup_module/teardown_module 模块始末,全局的(优先最高)
函数级: setup_function/teardown_function 只对函数用例生效(不在类中)
类级: setup_class/teardown_class 只在类中前后运行一次(在类中)
方法级: setup_method/teardown_methond 开始于方法始末(在类中)
方法级: setup/teardown 运行在调用方法的前后
1、简介:
fixture区别于unnitest的传统单元测试(setup/teardown)有显著改进:
1.有独立的命名,并通过声明它们从测试函数、模块、类或整个项目中的使用来激活。
2.按模块化的方式实现,每个fixture都可以互相调用。
3.fixture的范围从简单的单元测试到复杂的功能测试,可以对fixture配置参数,或者跨函数function,类class,模块module或整个测试session范围。
2、fixture的作用范围(scope)
fixture里面有个scope参数可以控制fixture的作用范围:session>module>class>function
-function:每一个函数或方法都会调用
-class:每一个类调用一次,一个类中可以有多个方法
-module:每一个.py文件调用一次,该文件内又有多个function和class
-session:是多个文件调用一次,可以跨.py文件调用,每个.py文件就是module
3.fixture参数详解
fixture(scope=‘function’,params=None,autouse=False,ids=None,name=None)
fixture里面有个scope参数可以控制fixture的作用范围,scope有4个级别参数:“function”(默认)、“class”、“module”、"session。
params:一个可选的参数列表,它将导致多个参数调用fixture功能和所有测试使用它。
autouse:如果True,则为所有测试激活fixture func可以看到它。如果为False则显示需要参考来激活fixture。
ids:每个字符串id的列表,每个字符串对应于params这样他们就是测试ID的一部分。如果没有提供ID它们将从params自动生成。
name:fixture的名称。这默认为装饰函数的名称。如果fixture在定义它的统一模块中使用,夹具的功能名称将被请求夹具的功能arg遮蔽,解决这个问题的一种方法时将装饰函数命令"fixture_“然后使用”@pytest.fixture(name=’’)"。
Pytest 测试框架的数据驱动是由 pytest 自带的***pytest.mark.parametrize()***来实现的。
方法:
parametrize(argnames, argvalues, indirect=False, ids=None, scope=None)
常用参数:
argnames:参数名
argvalues:参数对应值,类型必须为list或元组
当参数为一个时格式:[value]
当参数个数大于一个时,格式为:[(param_value1,param_value2.....),(param_value1,param_value2.....)]
ids:使用的数据组别名,类型必须为list或元组,与argvalues一一对应,用于使用的数据组的展示
使用方法:
@pytest.mark.parametrize(argnames,argvalues)
️ 参数值为N个,测试方法就会运行N次