首页 > 其他 > 详细

pytest修改测试用例执行顺序(钩子函数:pytest_collection_modifyitems)(针对单个测试文件中的测试用例)

时间:2021-07-26 22:56:54      阅读:26      评论:0      收藏:0      [点我收藏+]

前言

pytest默认执行用例是先根据项目下的文件夹名称按ascii码去收集的,module里面的用例是从上往下执行的。

Hook 方法之 pytest_collection_modifyitems:

pytest_collection_modifyitems 是在用例收集完毕之后被调用,可以用来调整测试用例执行顺序;
它有三个参数,分别是:

session:会话对象;
config:配置对象;
items:用例对象列表;
这三个参数分别有不同的作用,都可以拿来单独使用,修改用例执行顺序主要是使用 items 参数【用例执行之前,收集到的测试用例会以元素对象的方式存放在用例对象列表items中】

pytest_collection_modifyitems方法源码:

def pytest_collection_modifyitems(session, config, items):
    """ called after collection has been performed, may filter or re-order
    the items in-place.
    :param _pytest.main.Session session: the pytest session object
    :param _pytest.config.Config config: pytest config object
    :param List[_pytest.nodes.Item] items: list of item objects
    """

修改测试用例执行顺序

首先准备三个测试用例:

import pytest
 
class TestDemoA:
 
    def test_A_001(self):
        pass
 
    def test_A_002(self):
        pass
 
    def test_A_003(self):
        pass
 
if __name__ == __main__:
    pytest.main([-s])

正常情况下pytest 会按照从上到下的顺序依次执行(模块级会先以模块名按ascii编码进行排序):

技术分享图片

使用 pytest_collection_modifyitems 修改单个测试文件中的用例执行顺序

在 conftest.py 文件中 使用pytest_collection_modifyitems  钩子方法:

# conftest.py
 
# 在收集完测试用例后才会执行
def pytest_collection_modifyitems(items):
    print(pytest 收集到的所有测试用例:\n,items)
 
if __name__ == __main__:
    pytest.main([-s])

可以看到控制台中打印出来了收集到的三个测试用例的对象,而且是在测试用例执行之前便已经收集【先收集测试用例,然后执行测试用例】

在执行完 pytest_collection_modifyitems 之后才显示收集到了 3 个用例,如果我们在 pytest_collection_modifyitems 中对用例进行调整,便会影响用例是否执行和执行顺序;
技术分享图片 

利用 items 获取收集到的用例名和用例节点:

# conftest.py
 
def pytest_collection_modifyitems(items):
    print(pytest 收集到的所有测试用例:\n, items)
    for item in items:
        print(--- * 10)
        print(用例名:, item.name)
        print(用例节点:, item.nodeid)
 
if __name__ == __main__:
    pytest.main([-s])

运行结果:

技术分享图片

修改用例执行顺序和剔除测试用例:

# conftest.py
 
def pytest_collection_modifyitems(items):
    # 将用例名拿出来存入新列表new_items
    new_items = []
    for item in items:
        new_items.append(item.name)
 
    # 1. 删除 test_A_002 用例
    # 获取 test_A_002 在新列表的索引
    index_2 = new_items.index(test_A_002)
    # 在老列表中删除这个索引
    del items[index_2]
    del new_items[index_2]  # 新列表同步删除,和老列表保持同步
 
    # 2. 调换 1 和 3 的顺序
    # 获取 1 和 3 在新列表的索引
    index_1 = new_items.index(test_A_001)
    index_3 = new_items.index(test_A_003)
    # 根据索引在老列表中调换位置
    items[index_1], items[index_3] = items[index_3], items[index_1]

运行结果:

技术分享图片

可以看到控制台输出的结果中,用例3 和 用例1 的顺序调换了,用例2 由于被删除所以没有执行;

代码写的比较粗糙,但是思路就是这样:想办法干涉 items 中用例对象的排序;

pytest修改测试用例执行顺序(钩子函数:pytest_collection_modifyitems)(针对单个测试文件中的测试用例)

原文:https://www.cnblogs.com/hls-code/p/15063418.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!