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测试套件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
命令行传递参数argparse.ArgumentParser的使用解析
这篇文章主要介绍了命令行传递参数argparse.ArgumentParser的使用解析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-02-02python实现微信机器人: 登录微信、消息接收、自动回复功能
这篇文章主要介绍了python实现微信机器人: 登录微信、消息接收、自动回复功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-04-04
最新评论