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測試套件內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 基於Python的接口自動化unittest測試框架和ddt數據驅動詳解
- python單測框架之pytest常見用法
- python unittest單元測試的步驟分析
- python中unittest框架應用詳解
- pytest自動化測試中的fixture的聲明和調用