我只是短暂地使用unittest。我正在使用Jython 2.7.10“最终发布版”。
在Python 2.7文档中解释TestResult时,它说:
TestResult类的以下方法用于维护内部数据结构,并且可以在子类中进行扩展以支持其他报告要求。这对于在运行测试时构建支持交互式报告的工具非常有用。
startTest(test) ... stopTest(test) ... startTestRun() ... stopTestRun()¶
这就是我想做的... 但我不知道如何使用TestResult。下面是一个SSCCE示例...
import unittest
class TestResultX( unittest.TestResult ):
def startTest( self, test ):
print( '# blip')
unittest.TestResult.startTest( self, test )
def stopTest( self, test ):
print( '# blop')
unittest.TestResult.stopTest( self, test )
def startTestRun( self ):
print( '# blep')
unittest.TestResult.startTestRun( self )
def stopTestRun( self ):
print( '# blap')
unittest.TestResult.stopTestRun( self )
class TestCaseX( unittest.TestCase ):
def test_nonsense(self):
print( '# wotcha' )
self.assertTrue( False )
def run( self, test_result=None ):
print( '# spoons starting...')
test_result = TestResultX()
unittest.TestCase.run( self, test_result )
print( '# ...spoons ended, tr %s' % ( test_result, ) )
unittest.main()
结果是:
# spoons starting...
----------------------------------------------------------------------
Ran 0 tests in 0.015s
OK
# blip
# wotcha
# blop
# ...spoons ended, tr <__main__.TestResultX run=1 errors=0 failures=1>
问题:
- 为什么显示为
0 tests
? blep
和blap
(运行的开始和结束)为什么没有打印出来?
更一般地说:
有人可以指点一下好的教程/书籍,解释TestResult、TestRunner、TestLoader等的“正确使用”/“最佳实践”吗?我看了《Python TDD》,但似乎没有解释这些。
有人可以告诉我为什么经常使用unittest2而不是unittest吗?
附录
在Omar Diab查看源代码的努力之后,我尝试了这个:
def run( self, *args, **kvargs ):
result = self.defaultTestResult()
startTestRun = getattr(result, 'startTestRun', None)
logger.info( '# calling superclass run... startTestRun? %s' % ( startTestRun, ))
unittest.TestCase.run( self, *args, **kvargs )
logger.info( '# ... superclass run ended')
很不幸,每个 test_XXX 方法都返回了以下结果:
# calling superclass run... startTestRun? <bound method TestResult.startTestRun of <unittest.result.TestResult run=0 errors=0 failures=0>>
setUp for test_that_stuff_happened (__main__.xx_FT)
tearDown for test_that_stuff_happened (__main__.xx_FT)
end tearDown...
. # ... superclass run ended