微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

计算Python单元测试中的子测试

从3.4版开始,Python supports a simple subtest syntax when writing unittests.一个简单的例子可能如下所示:

import unittest

class NumbersTest(unittest.TestCase):

    def test_successful(self):
        """A test with subtests that will all succeed."""
        for i in range(0,6):
            with self.subTest(i=i):
                self.assertEqual(i,i)

if __name__ == '__main__':
    unittest.main()

运行测试时,输出将是

python3 test_foo.py --verbose
test_successful (__main__.NumbersTest)
A test with subtests that will all succeed. ... ok

----------------------------------------------------------------------
Ran 1 test in 0.000s

OK

但是,在我的实际用例中,子测试将依赖于更复杂的迭代,并检查每个子测试的非常不同的东西.因此,我宁愿让每个子测试计数并在输出中列出一个单独的测试用例(在本例中为Ran 6测试)以获得完整的图像.

这在Python中使用plain unittest模块是否可行? The nose test generator feature将单独输出每个测试,但如果可能的话,我希望与标准库保持兼容.

解决方法

你可以继承unittest.TestResult:

class NumbersTestResult(unittest.TestResult):
    def addSubTest(self,test,subtest,outcome):
        # handle failures calling base class
        super(NumbersTestResult,self).addSubTest(test,outcome)
        # add to total number of tests run
        self.testsRun += 1

然后在NumbersTest中覆盖run函数

def run(self,test_result=None):
    return super(NumbersTest,self).run(NumbersTestResult())

对不起,我现在无法在完全正常工作的环境中对此进行测试,但这应该可以解决问题.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐