我正在寻找一个演示如何使用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。