栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Pytest学习笔记(20)-参数化parametrize结合allure.title()动态生成用例标题

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Pytest学习笔记(20)-参数化parametrize结合allure.title()动态生成用例标题

文章目录

前言参数化默认的标题

代码测试报告 参数化使用id

代码测试报告 参数化+allure.title()写死标题

代码测试报告 参数化使用ids

代码测试报告 参数化+allure.title()动态生成标题

代码测试报告小结

前言

使用参数化,allure报告默认的用例标题为用例名称,这样可读性较差参数化使用ids,也并不能完全解决问题(还是会保留用例名称)使用allure.title()装饰器写死标题的方式,用例维护成本较高所以希望能把parametrize参数化数据驱动结合title使用,下面会以登录用例为例来详细介绍 参数化默认的标题 代码

data_login = [
    {"username": "name1", "pwd": "pwd1"},
    {"username": "name2", "pwd": "pwd2"},
    {"username": "name3", "pwd": "pwd3"}
]


@pytest.fixture()
def login(request):
    """登录fixture"""
    param = request.param
    print(f"账号是:{param['username']},密码是:{param['pwd']}")
    # 返回
    return {"code": 0, "msg": "success!"}


# 参数化默认的标题
@pytest.mark.parametrize("login", data_login, indirect=True)
def test_parametrize_without_title(login):
    assert login['code'] == 0
测试报告


用例标题为方法名+参数化数据,可读性较差

参数化使用id 代码
data_login = [
    pytest.param({"username": "name1", "pwd": "pwd1"}, id="name1登录成功"),
    pytest.param({"username": "name2", "pwd": "pwd2"}, id="name2登录失败"),
    pytest.param({"username": "name3", "pwd": "pwd3"}, id="name3用户名不存在")
]


@pytest.fixture()
def login(request):
    """登录fixture"""
    param = request.param
    print(f"账号是:{param['username']},密码是:{param['pwd']}")
    # 返回
    return {"code": 0, "msg": "success!"}


# 参数化使用id
@pytest.mark.parametrize("login", data_login, indirect=True)
def test_parametrize_without_id(login):
    assert login['code'] == 0
测试报告


使用pytest.param(id=xxx) 的方法只是将参数化的id自定义化,并未达到修改用例标题的效果

参数化+allure.title()写死标题 代码
data_login = [
    {"username": "name1", "pwd": "pwd1"},
    {"username": "name2", "pwd": "pwd2"},
    {"username": "name3", "pwd": "pwd3"}
]

# 参数化+allure.title()写死标题
@allure.title("登录测试用例:name1成功,name2失败,name3用户名不存在")
@pytest.mark.parametrize("login", data_login, indirect=True)
def test_parametrize_without_id(login):
    assert login['code'] == 0
测试报告

达到了标题的效果但是三条用例的标题都相同,可见并不适合结合参数化使用且用例的标题都是写死到用例文件内,未实现数据和用例的解耦,可维护性较差 参数化使用ids 代码

# 数据驱动
data_login = [
    {"username": "name1", "pwd": "pwd1"},
    {"username": "name2", "pwd": "pwd2"},
    {"username": "name3", "pwd": "pwd3"}
]
login_ids = ["name1登录成功", "name2登录失败", "name3用户名不存在"]


# 参数化使用ids
@pytest.mark.parametrize("login", data_login, ids=login_ids, indirect=True)
def test_parametrize_without_id(login):
    assert login['code'] == 0
测试报告


效果和使用pytest.param(id=xxx) 的方法,完全一致,未达到预期效果

参数化+allure.title()动态生成标题 代码
data_login_with_fixture = [
    {"username": "name1", "pwd": "pwd1"},
    {"username": "name2", "pwd": "pwd2"},
    {"username": "name3", "pwd": "pwd3"}
]


# 参数化+allure.title()动态生成标题,结合fixture
@allure.title("登录用例-{login}")
@pytest.mark.parametrize("login", data_login_with_fixture, indirect=True)
def test_parametrize_without_id(login):
    assert login['code'] == 0


data_login_without_fixture = [
    ("name1", "123456", "name1 登录成功"),
    ("name2", "123456", "name2 登录失败"),
    ("name3", "123456", "name3 账号不存在")
]


# 参数化+allure.title()动态生成标题,不结合fixture
@allure.title("登录-{title}")
@pytest.mark.parametrize("username,pwd,title", data_login_without_fixture)
def test_parametrize_without_id(username, pwd, title):
    pass
测试报告

小结

如果有入参传入fixture,尽量不要使用title动态生成无上述条件,使用参数化+allure.title()可动态生成用例标题,更加灵活用例标题可以直接放到数据驱动内去维护,可维护性较高不会影响测试报告的可读性,可以看到和写死的title效果一致

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/753079.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号