2 回答
TA贡献1829条经验 获得超7个赞
作为最简单的方法之一 - 只是将输入(Python 2 的 raw_input)放在 cleanResource 方法的开头。所以执行将停止,直到按下 Enter 键。
def cleanResource(self):
temp = raw_input('wait before cleanResource')
print("\nmessage from function: cleanResource")
另一种方法是在调试器中使用断点
import pdb
进而
pdb.set_trace()
需要的地方
TA贡献1829条经验 获得超4个赞
根据单元测试文档doCleanups()是负责调用所有清理方法的方法。
一种方法是在 doCleanups 方法中检查测试用例的结果,如果测试用例失败则弹出所有清理方法并跳过其余测试用例
下面是代码:
import unittest
class SimpleTestCases(unittest.TestCase):
FAILURE = False
def setUp(self):
print "\nmessage from function: setUp"
if SimpleTestCases.FAILURE:
self.skipTest("Test is skipped due to first failure")
return super(SimpleTestCases, self).setUp()
self.createResource()
self.addCleanup(self.cleanResource)
def createResource(self):
msg = "\nmessage from function: createResource"
def cleanResource(self):
print "\nmessage from function: cleanResource"
def test_func1(self):
print "message from function: test_func1::start"
print "message from function: test_func1::end"
def test_func2(self):
print "message from function: test_func2::start"
self.assertTrue(False)
print "message from function: test_func2::end"
def test_func3(self):
print "message from function: test_func3::start"
print "message from function: test_func3:end"
def doCleanups(self):
print "message from function: doCleanups"
if SimpleTestCases.FAILURE:
return super(SimpleTestCases, self).doCleanups()
result = getattr(self, '_outcomeForDoCleanups', self._resultForDoCleanups)
ok_result = True
exc_list = getattr(result, 'failures')
if exc_list and exc_list[-1][0] is self:
ok_result = ok_result and not exc_list[-1][1]
if not ok_result:
SimpleTestCases.FAILURE = True
while self._cleanups:
(func, args, kwargs) = self._cleanups.pop()
return super(SimpleTestCases, self).doCleanups()
if __name__ == "__main__":
result = unittest.main()
执行为
python -m unittest test_cases
和输出:
message from function: setUp
message from function: test_func1::start
message from function: test_func1::end
message from function: doCleanups
message from function: cleanResource
.
message from function: setUp
message from function: test_func2::start
Fmessage from function: doCleanups
message from function: setUp
smessage from function: doCleanups
======================================================================
FAIL: test_func2 (test_cases.SimpleTestCases)
----------------------------------------------------------------------
Traceback (most recent call last):
File "test_cases.py", line 30, in test_func2
self.assertTrue(False)
AssertionError: False is not true
----------------------------------------------------------------------
Ran 3 tests in 0.000s
FAILED (failures=1, skipped=1)
添加回答
举报