有没有自定义方法来收集 pytest 结果? [英] Is there a custom way to collect pytest results?
本文介绍了有没有自定义方法来收集 pytest 结果?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想查看刚刚运行的测试结果,以便我可以通过管道传输信息,例如到自定义文件中.这将在稍后用于自动解析 pytest 结果.
I want to see the results of the tests that just run such that I can pipe the information e.g. into a custom file. This will be used later on to automatically parse the pytest results.
推荐答案
是的,有一种方法可以通过创建/使用 conftest.py.在示例中,将创建一个带有结果的字典,并在所有测试运行后打印结果.
Yes there is a way by creating / using the conftest.py. In the example a dict with the results will be created and after all tests have run the results will printed.
from collections import OrderedDict
test_results = OrderedDict()
def get_current_test():
"""Just a helper function to extract the current test"""
full_name = os.environ.get('PYTEST_CURRENT_TEST').split(' ')[0]
test_file = full_name.split("::")[0].split('/')[-1].split('.py')[0]
test_name = full_name.split("::")[1]
return full_name, test_file, test_name
@pytest.hookimpl(tryfirst=True, hookwrapper=True)
def pytest_runtest_makereport(item, call):
"""The actual wrapper that gets called before and after every test"""
global test_results
outcome = yield
rep = outcome.get_result()
# only check the result of the test
if rep.when == "call":
full_name, test_file, test_name = get_current_test()
test_name_msg = f"{test_name}_msg"
if rep.failed:
test_results[test_name] = "Failure"
# return the last error msg either by pytest.fail or from any exception raised
test_results[test_name_msg] = f"{call.excinfo.typename} - {call.excinfo.value}"
else:
test_results[test_name] = "Success"
test_results[test_name_msg] = ''
def pytest_unconfigure(config):
"""Called when pytest is about to end. Can be used to print the result dict or
to pipe the data into a file"""
print(test_results)
这篇关于有没有自定义方法来收集 pytest 结果?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文