unittest框架系列四(子测试subTest)

子测试subTest

欢迎加入测试交流群:夜行者自动化测试(816489363)进行交流学习QAQ

–成都-阿木木


如果测试方法内,还需要对某些差异非常小的参数进行测试,unittest支持使用subTest()上下文管理器在测试方法的内部区分他们,也就是说,我们可以在测试方法的内部进行调用的测试方法的测试,也就是测试方法嵌套,可以传递一个参数集(数据驱动)对于子测试方法进行测试,子测试方法会针对参数集(数据驱动)中的每一个参数值,进行测试结果的输出。

class NumbersTest(unittest.TestCase):

    def test_even(self):
        """
        Test that numbers between 0 and 5 are all even.
        """
        for i in range(0, 6):
            with self.subTest(i=i):
                self.assertEqual(i % 2, 0)
结果为:
======================================================================
FAIL: test_even (__main__.NumbersTest) (i=1)
Test that numbers between 0 and 5 are all even.
----------------------------------------------------------------------
Traceback (most recent call last):
  File "D:/TestScriptDir/python_web/mysite/unittest_demo.py", line 25, in test_even
    self.assertEqual(i % 2, 0)
AssertionError: 1 != 0

======================================================================
FAIL: test_even (__main__.NumbersTest) (i=3)
Test that numbers between 0 and 5 are all even.
----------------------------------------------------------------------
Traceback (most recent call last):
  File "D:/TestScriptDir/python_web/mysite/unittest_demo.py", line 25, in test_even
    self.assertEqual(i % 2, 0)
AssertionError: 1 != 0

======================================================================
FAIL: test_even (__main__.NumbersTest) (i=5)
Test that numbers between 0 and 5 are all even.
----------------------------------------------------------------------
Traceback (most recent call last):
  File "D:/TestScriptDir/python_web/mysite/unittest_demo.py", line 25, in test_even
    self.assertEqual(i % 2, 0)
AssertionError: 1 != 0

----------------------------------------------------------------------
Ran 1 test in 0.001s

FAILED (failures=3)

如果不使用子测试,则在第一次失败后执行将停止,并且错误将不那么容易诊断,因为i 不会显示的值:

FAIL: test_even (__main__.NumbersTest)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "subtests.py", line 32, in test_even
    self.assertEqual(i % 2, 0)
AssertionError: 1 != 0
在 Python 的 `unittest` 测试框架中,`TestSuite` 是用于组织和运行多个测试用例的核心机制之一。它允许将多个测试用例或测试类组合在一起,并按照指定顺序执行[^3]。 ### 1. 创建测试套件 首先需要创建一个 `TestSuite` 实例,这可以通过调用 `unittest.TestSuite()` 来完成: ```python suite = unittest.TestSuite() ``` ### 2. 添加测试用例到测试套件 #### 单个添加测试方法 可以使用 `addTest()` 方法将单个测试方法添加到测试套件中: ```python suite.addTest(TestMathMethod('test_two_num_add')) ``` 这种方法适用于仅需执行特定的测试方法的情况[^1]。 #### 批量添加测试类中的所有测试用例 通过 `TestLoader().loadTestsFromTestCase()` 可以将某个测试类中的所有测试用例批量添加进测试套件: ```python suite.addTest(unittest.TestLoader().loadTestsFromTestCase(TestMathMethod)) ``` 该方式适合一次性加载某测试类下的全部测试用例[^1]。 #### 从模块批量加载测试用例 如果测试用例分布在不同的模块中,可以通过 `TestLoader().loadTestsFromModule()` 加载整个模块内的测试用例: ```python import test_module # 替换为实际的模块名 suite.addTest(unittest.TestLoader().loadTestsFromModule(test_module)) ``` 这种方式适用于模块内有多个测试类且需要统一执行的情况[^1]。 #### 按名称添加测试用例 还可以通过 `TestLoader().loadTestsFromName()` 指定具体的测试用例名称进行加载: ```python suite.addTest(unittest.TestLoader().loadTestsFromName('test_two_num_sub', test_module)) ``` 此方法适合只关注特定测试用例时使用。 #### 使用 discover 动态发现并加载测试用例 最后,`discover` 方法可以根据文件路径动态发现符合命名规则的测试模块,并自动加载其中的测试用例: ```python suite.addTest(unittest.TestLoader().discover(r'path_to_test_directory', pattern='test_*')) ``` 这种策略非常适合项目规模较大、测试用例分布广泛时使用,可以避免手动逐个添加测试用例。 ### 3. 执行测试套件 一旦测试用例被成功添加到测试套件中,就可以通过 `TextTestRunner` 来执行这些测试: ```python runner = unittest.TextTestRunner() runner.run(suite) ``` 这段代码会输出详细的测试执行结果,包括每个测试用例的状态(成功、失败或错误)以及总的测试统计信息[^2]。 ###
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值