how to get the traceback of failed test (unittest) in the tearDown() function(如何在tearDown()函数中获取失败测试(Unittest)的回溯)
本文介绍了如何在tearDown()函数中获取失败测试(Unittest)的回溯的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我希望将我运行的每个失败测试的所有异常的所有回溯保存到外部文件中。 我希望使用unittest的teardown,而不是在每个测试中使用try和Except,这样会更通用。
类似:
import traceback
import unittest
class SomeTestCase(unittest.TestCase):
def setUp(self):
pass
def test_some_test(self):
self.assertTrue(False)
def tearDown(self):
with open(logger.txt, 'a') as doc:
doc.write(traceback.format_exc())
问题是,无法使用tearDown中的回溯调用您在test_ome_test中获得的异常(tracebacke返回NONE)
有什么建议吗?
推荐答案
所以在我检查了一大段单元测试代码后,我找到了一个解决方案!
TestCase
类具有_outcome
属性。_outcome
有一个名为errors
的列表类型属性。
errors[0][1]
是与包含回溯的sys.exc_info()
输出完全相同的元组。现在我有了这个元组,我可以在
traceback.format_exception()
中使用它,就像traceback.format_exc()
使用它并解决问题一样。
def tearDown(self):
try:
etype, value, tb = self._outcome.errors[0][1]
trace = ''.join(traceback.format_exception(etype=etype, value=value, tb=tb, limit=None))
date = '{date}
'.format(date=str(datetime.datetime.now()))
name = '
' + self._testMethodName + '-
'
with open(self.logger, 'a') as doc:
doc.write(name + date + trace)
except:
pass
这篇关于如何在tearDown()函数中获取失败测试(Unittest)的回溯的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何在tearDown()函数中获取失败测试(Unittest)的回溯


基础教程推荐
猜你喜欢
- 将 YAML 文件转换为 python dict 2022-01-01
- 使用 Google App Engine (Python) 将文件上传到 Google Cloud Storage 2022-01-01
- 如何在Python中绘制多元函数? 2022-01-01
- 症状类型错误:无法确定关系的真值 2022-01-01
- 使用Python匹配Stata加权xtil命令的确定方法? 2022-01-01
- 合并具有多索引的两个数据帧 2022-01-01
- 如何在 Python 中检测文件是否为二进制(非文本)文 2022-01-01
- 使 Python 脚本在 Windows 上运行而不指定“.py";延期 2022-01-01
- 哪些 Python 包提供独立的事件系统? 2022-01-01
- Python 的 List 是如何实现的? 2022-01-01