self._outcome.result.failures
时间: 2023-10-29 14:04:38 浏览: 36
self._outcome.result.failures是一个列表,包含了测试失败的测试用例的信息。每个元素是一个包含两个元素的元组,第一个元素是测试用例的名称,第二个元素是一个Traceback对象,其中包含了测试用例执行失败的详细信息,比如错误类型、错误信息、错误发生的行数等等。这个列表可以用于测试报告的生成或者对测试结果的分析。
相关问题
def wraper_func(test_func): @wraps(test_func) # @wraps:避免被装饰函数自身的信息丢失 def inner_func(self): failures = str([fail[0] for fail in self._outcome.result.failures]) if test_func.__name__ in failures: if self._id() == self._testMethodName: test = False else: test = True else: test = True return test(self) if inner_func(self) == True: return True else: return False 这个代码有错吗,怎么更改
这段代码有一些问题。首先,在 `inner_func` 函数中,`test` 变量被赋值为一个布尔值,但在返回时却被当作了一个函数来调用。其次,在 `wraper_func` 函数中,`inner_func` 函数应该返回一个函数对象,而不是一个布尔值。
以下是更改后的代码:
```
from functools import wraps
def wraper_func(test_func):
@wraps(test_func)
def inner_func(self):
failures = str([fail[0] for fail in self._outcome.result.failures])
if test_func.__name__ in failures:
if self._id() == self._testMethodName:
test = lambda: False
else:
test = lambda: True
else:
test = lambda: True
return test
return inner_func(self)
# 测试
class Test:
def test_func(self):
return True
test = Test()
result = wraper_func(test.test_func)
print(result()) # 输出 True
```
在更改后的代码中,`inner_func` 函数返回一个匿名函数,该函数根据条件返回 `True` 或 `False`。在 `wraper_func` 函数中,我们调用 `inner_func` 并传入 `self` 参数,该参数在测试类的实例化对象中提供。然后,我们将返回的函数对象存储在 `result` 变量中,并在需要时调用它来执行测试。
def skip_dependon(depend): """ :param depend: 依赖的用例函数名,默认为空 :return: wraper_func """ def wraper_func(test_func): @wraps(test_func) # @wraps:避免被装饰函数自身的信息丢失 def inner_func(self): if depend == test_func.__name__: raise ValueError("{} cannot depend on itself".format(depend)) failures = str([fail[0] for fail in self._outcome.result.failures]) errors = str([error[0] for error in self._outcome.result.errors]) # skipped = str([error[0] for error in self._outcome.result.skipped]) or (depend in skipped) flag = (depend in failures) or (depend in errors) if failures.find(depend) != -1: test = unittest.skipIf(flag, "{} failed".format(depend))(test_func) elif errors.find(depend) != -1: test = unittest.skipIf(flag, "{} error".format(depend))(test_func) # elif skipped.find(depend) != -1: # test = unittest.skipIf(flag, "{} skipped".format(depend))(test_func) else: test = test_func return test(self) return inner_func return wraper_func
这是一个装饰器函数,用于给unittest的测试用例函数添加依赖关系。它接受一个参数`depend`,表示这个测试用例函数依赖的函数名,默认为空。它返回一个函数`wraper_func`,这个函数又返回一个函数`inner_func`,这个函数是对测试用例函数进行装饰的实际函数。
`inner_func`中首先对依赖函数名进行判断,如果依赖函数名和测试用例函数名相同,则抛出异常,因为一个测试用例不能依赖于自己。
然后通过`self._outcome.result`来获取测试结果,并判断依赖函数的测试结果。如果依赖函数执行失败(failures),则用`unittest.skipIf`装饰器将测试用例函数标记为跳过,跳过的原因是依赖函数执行失败。同样的,如果依赖函数执行出错(errors),也会将测试用例函数标记为跳过。
最后返回装饰后的测试用例函数。