Pytest执行unittest TestSuite(测试套件)的实现方法

 更新时间:2021年08月31日 09:38:43   作者:韩志超  
TestSuite一直是unittest的灵活与精髓之处,在繁多的测试用例中,可以任意挑选和组合各种用例集,这篇文章主要介绍了Pytest执行unittest TestSuite(测试套件)的实现方法,需要的朋友可以参考下

前言

TestSuite一直是unittest的灵活与精髓之处,在繁多的测试用例中,可以任意挑选和组合各种用例集,比如smoke用例集、level1用例集、webtest用例集、bug回归用例集等等,当然这些TestSuite需要我们提前定义好,并把用例加载进去。Pytest采取的是完全不同的用例组织和运行方式。用例的运行主要基于名称匹配;组织则基于用例目录,用例命名格式及用例mark标签, 这种方式省去了麻烦的提前定义TestSuite及加载用例的过程,执行时通过路径/用例名格式/不同的标签组合来动态匹配出要执行的用例,使用更加灵活。然而,从原有的unittest框架转向pytest怀抱时仍不得不面临这样一个问题:我原先定义好的TestSuite怎么执行?

实现方法

主要思路:

①迭代遍历TestSuite中的所有case得到每个case的路径test_demo.TestDemo.test_a

②将case路径转化为Pytest支持的运行格式test_demo.py::TestDemo::test_a并组成一个case名称列表供Pytest调用。

示例用例: test_demo.py:

import unittest

class TestDemo(unittest.TestCase):
    def test_a(self):
        print("a")

    def test_b(self):
        print("b")

示例测试套件:demo.py:

import unittest
import pytest
from test_demo import TestDemo

suite = unittest.TestSuite()
suite.addTests([TestDemo('test_a'), TestDemo('test_b')])

# 因为suite中可能会存在嵌套, 所以我们要迭代取出其中所有的用例:
def collect(suite): 
    cases = []  # 用于存放Pytest支持的用例路径字符串

    def _collect(tests):   # 递归,如果下级元素还是TestSuite则继续往下找
        if isinstance(tests, unittest.TestSuite):
            [_collect(i) for i in tests if tests.countTestCases() != 0] 
        else:
            _path = tests.id().split(".")  # case.id()可以获取用例路径(字符串)
            _path[0] += ".py"
            cases.append("::".join(_path))  # 如果下级元素是TestCase,则添加到TestSuite中

    _collect(suite)
    return cases

if __name__ == '__main__':
    cases = collect(suite)
    pytest.main([*cases, "-v"])
    # pytest.main(cases)  # 不加额外参数的化可直接执行cases

到此这篇关于Pytest执行unittest TestSuite(测试套件)的实现方法的文章就介绍到这了,更多相关Pytest unittest TestSuite测试套件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python连接mysql实例分享

    python连接mysql实例分享

    本文给大家汇总介绍了使用python连接mysql的几个实例,非常的简单实用,有需要的小伙伴可以参考下
    2016-10-10
  • 教你一步步利用python实现贪吃蛇游戏

    教你一步步利用python实现贪吃蛇游戏

    这篇文章主要给大家介绍了关于如何利用python实现贪吃蛇游戏的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • python字典排序的方法

    python字典排序的方法

    在本篇文章里小编给大家整理的是关于python字典怎么排序的相关知识点内容,有兴趣的朋友们学习下。
    2019-10-10
  • python解决字典中的值是列表问题的方法

    python解决字典中的值是列表问题的方法

    这篇文章主要介绍了字典中的值是列表问题,先用value连成一个str,最后用str.split()作一个转换,生成一个列表.看了python cookbook,上面正好有一个recipe讲到如何处理这样的问题
    2013-03-03
  • python 实现得到当前时间偏移day天后的日期方法

    python 实现得到当前时间偏移day天后的日期方法

    今天小编就为大家分享一篇python 实现得到当前时间偏移day天后的日期方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-12-12
  • python基于watchdog库全自动化监控目录文件

    python基于watchdog库全自动化监控目录文件

    这篇文章主要介绍了python基于watchdog库全自动化监控目录文件,帮助大家更好的理解和学习使用python,感兴趣的朋友可以了解下
    2021-03-03
  • 使用Python文件读写,自定义分隔符(custom delimiter)

    使用Python文件读写,自定义分隔符(custom delimiter)

    这篇文章主要介绍了使用Python文件读写,自定义分隔符(custom delimiter),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • python中pop()函数的语法与实例

    python中pop()函数的语法与实例

    这篇文章主要给大家介绍了关于python中pop()函数语法与实例的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • 对python PLT中的image和skimage处理图片方法详解

    对python PLT中的image和skimage处理图片方法详解

    今天小编就为大家分享一篇对python PLT中的image和skimage处理图片方法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-01-01
  • python爬虫入门教程--优雅的HTTP库requests(二)

    python爬虫入门教程--优雅的HTTP库requests(二)

    requests 实现了 HTTP 协议中绝大部分功能,它提供的功能包括 Keep-Alive、连接池、Cookie持久化、内容自动解压、HTTP代理、SSL认证等很多特性,下面这篇文章主要给大家介绍了python爬虫入门中关于优雅的HTTP库requests的相关资料,需要的朋友可以参考下。
    2017-05-05

最新评论