我正在寻找一个演示如何使用testtool's并发测试的简单示例。我从here找到了一个例子:

import unittest
import testtools

class MyTester(unittest.TestCase):
    # Tests...

suite = unittest.TestLoader().loadTestsFromTestCase(MyTester)
concurrent_suite = testtools.ConcurrentStreamTestSuite(lambda: ((case, None) for case in suite))
concurrent_suite.run(testtools.StreamResult())

但是,它有一个很大的问题。它不会告诉您测试是通过还是失败。 StreamResult对象不仅是临时的,而且StreamResult的方法也不做任何事情。

最佳答案

根据 StreamResult documentation,调用status方法来处理事件,并且默认实现不执行任何操作。

要使其打印某些内容,您需要继承它以执行所需的操作。例如,要打印正在发生的事情:

import unittest
import testtools

class MyTester(unittest.TestCase):
    def test_foo(self):
        self.assertEqual(1+2, 2)
    def test_foo2(self):
        self.assertEqual(1+2, 3)

class TracingStreamResult(testtools.StreamResult):
    def status(self, *args, **kwargs):
        print('{0[test_id]}: {0[test_status]}'.format(kwargs))

suite = unittest.TestLoader().loadTestsFromTestCase(MyTester)
concurrent_suite = testtools.ConcurrentStreamTestSuite(lambda: ((case, None) for case in suite))
result = TracingStreamResult()
result.startTestRun()
concurrent_suite.run(result)
result.stopTestRun()

但是,已经有多个类继承了StreamResult。因此,您可能不需要定义自己的版本。参见Extensions to TestResult

10-06 11:54