pytest入门四:参数化

当测试数据和期望结果不一样,但操作步骤是一样的测试用例可以用上参数化。

@pytest.mark.parametrize(argnames, argvalues, indirect=False, ids=None)

参数说明:

argnames: 一个或多个参数名,用逗号分隔的字符串,如"arg1,arg2,arg3",参数名与用例入参数一致。

**argvalues:**参数值,必须是列表类型;如果有多个参数,则用元组存放值,一个元组存放一组参数值,元组放在列表中。

**indirect:**如果设置成True,则把传进来的参数当函数执行,而不是一个参数。

默认是False

False: 就是parametrize里面argnames 参数当作一个普通的变量,不会去找变量对应函数的名的方法

True: 就是parametrize里面argnames 参数当作函数执行,它会去找对应的函数,去执行

如下:

第一种,test_a就是一个单纯的变量,它接收的就是 "1", "2", "3",将这写数据传给了 test_login1用例。

第二种,test_a就不是一个变量,把它当作一个函数,将 "1", "2", "3" 数据给了test_a函数,函数的返回结果再传给了 test_login2用例。

**ids:**用例的ID,传一个字符串列表,可以标识每一个测试用例,自定义测试数据结果的显示,为了增加可读性,ids的长度需要与测试数据列表的长度一致。

复制代码
import pytest

def add(a,b):
    return a + b


@pytest.mark.parametrize("a,b,expect",[
    [1,2,3],
    [2,3,5],
    [1,5,6]
])
def test_add(a,b,expect):
    assert add(a,b) == expect

@pytest.mark.parametrize("a,b,expect",[
    (1,2,3),
    (2,3,5),
    (1,5,6)
],ids=['test1','test2','test3'])
def test_add2(a,b,expect):
    assert add(a,b) == expect


@pytest.mark.parametrize("data",[
    {'a':1,'b':2,'expect':3},
    {'a':2,'b':2,'expect':4}
])
def test_add3(data):
    assert add(data['a'],data['b']) == data['expect']


@ pytest.mark.parametrize("a,b,expect",[
    pytest.param(1,1,2,id="pass"),
    pytest.param(1.2,.2,2.4,id="fail")
])
def test_add4(a,b,expect):
    assert add(a,b) == expect


# 标记参数化
@pytest.mark.parametrize("test_input,expected", [
    ("3+5", 8),
    pytest.param("6 * 9", 42, marks=pytest.mark.xfail,id='xfial'),
    pytest.param("6*6", 42, marks=pytest.mark.skip)
])
def test_mark(test_input, expected):
    assert eval(test_input) == expected

# 笛卡尔积,组合数据
data_1 = [1, 2, 3]
data_2 = ['a', 'b']


@pytest.mark.parametrize('a', data_1)
@pytest.mark.parametrize('b', data_2)
def test_parametrize_1(a, b):
    print(f'笛卡尔积 测试数据为 : {a},{b}')

@pytest.mark.parametrize("test_a",["1","2","3"],indirect=False)
def test_login1(test_a):
    print(f"测试数据为:{test_a}")

@pytest.fixture()
def test_a(request):
    return "函数:"+request.param

@pytest.mark.parametrize("test_a",["1","2","3"],indirect=True)
def test_login2(test_a):
    print(f"测试数据为:{test_a}")
    

if __name__ == "__main__":
    pytest.main(['-v', '-s','test.py'])

结果:

collecting ... collected 25 items

test.py::test_add1-2-3 PASSED

test.py::test_add2-3-5 PASSED

test.py::test_add1-5-6 PASSED

test.py::test_add2test1 PASSED

test.py::test_add2test2 PASSED

test.py::test_add2test3 PASSED

test.py::test_add3data0 PASSED

test.py::test_add3data1 PASSED

test.py::test_add4pass PASSED

test.py::test_add4fail FAILED

test.py::test_mark3+5-8 PASSED

test.py::test_markxfial XFAIL

test.py::test_mark6\*6-42 SKIPPED (unconditional skip)

test.py::test_parametrize_1a-1 笛卡尔积 测试数据为 : 1,a

PASSED

test.py::test_parametrize_1a-2 笛卡尔积 测试数据为 : 2,a

PASSED

test.py::test_parametrize_1a-3 笛卡尔积 测试数据为 : 3,a

PASSED

test.py::test_parametrize_1b-1 笛卡尔积 测试数据为 : 1,b

PASSED

test.py::test_parametrize_1b-2 笛卡尔积 测试数据为 : 2,b

PASSED

test.py::test_parametrize_1b-3 笛卡尔积 测试数据为 : 3,b

PASSED

test.py::test_login11 测试数据为:1

PASSED

test.py::test_login12 测试数据为:2

PASSED

test.py::test_login13 测试数据为:3

PASSED

test.py::test_login21 测试数据为:函数:1

PASSED

test.py::test_login22 测试数据为:函数:2

PASSED

test.py::test_login23 测试数据为:函数:3

PASSED

相关推荐
007张三丰10 小时前
软件测试专栏(11/20):测试框架开发:pytest深度解析与插件体系
运维·服务器·自动化测试·pytest·测试框架
我的xiaodoujiao20 小时前
API 接口自动化测试详细图文教程学习系列25--继续处理testCase中的数据
python·学习·测试工具·pytest
xiaobai1782 天前
pytest+playwright实现UI自动化(4)-上夹具fixture
ui·自动化·pytest·playwright
弹简特2 天前
【接口自动化】02-Pytest固件fixture核心机制与Allure企业级报告实战
自动化·pytest·测试
弹简特4 天前
【接口自动化】01-pytest详解、pytest执行逻辑、pytest参数、配置文件和pytest标记
自动化·pytest
香辣西红柿炒蛋4 天前
pytest框架介绍
python·pytest
我的xiaodoujiao10 天前
API 接口自动化测试详细图文教程学习系列24--如何用Pytest去设计接口测试用例并执行
python·学习·测试工具·pytest
我的xiaodoujiao10 天前
API 接口自动化测试详细图文教程学习系列23--结合Pytest框架使用4-前后置处理
python·学习·测试工具·pytest
wanglei20070811 天前
pytest自动化测试框架项目架构
pytest
词元Max14 天前
2.12 pytest 实战:如何测试 AI 应用
人工智能·pytest