unittest_测试报告(6)

用例执行完成后,执行结果默认是输出在屏幕上,其实我们可以把结果输出到一个文件中,形成测试报告。

unittest自带的测试报告是文本形式的,如下代码:

import unittest


if __name__ == '__main__':
    # 识别指定目录下所有以test开头的文件以及文件中的用例,并将用例自动添加到测试套中
    test_cases_dir = "./test_cases/"
    suite = unittest.defaultTestLoader.discover(test_cases_dir)

    with open("./report.txt", "w") as report:
        # 生成执行器
        runner = unittest.TextTestRunner(stream=report, verbosity=2)
        # 执行用例
        runner.run(suite)

生成的报告如下

这种测试报告不能直观地展示用例执行情况,我们可以引入第三方模块展示一份详细的测试报告

常用的第三方模块有

  • BeautifulReport
  • HTMLTestRunner

BeautifulReport

使用pip安装BeautifulReport模块

pip install BeautifulReport

代码如下

import unittest
from BeautifulReport import BeautifulReport


if __name__ == '__main__':
    # 识别指定目录下所有以test开头的文件以及文件中的用例,并将用例自动添加到测试套中
    test_cases_dir = "./test_cases/"
    suite = unittest.defaultTestLoader.discover(test_cases_dir)

    # 执行用例并生成报告
    runner = BeautifulReport(suite)
    runner.report(
        description="全量用例",    # 用例描述
        filename="report",       # 报告文件名称
        report_dir="./"          # 报告存放路径
    )
    
    # 拓展:下面这行代码写不写都不影响报告生成,如果想自己写个报告界面,可以利用下面的用例执行结果
    # 获取用例执行结果,注意,只有在执行了report方法后才会有执行结果。
    ret = runner.fields
    print(ret)

执行结果如下

报告界面如下

HTMLTestRunner

使用pip安装HTMLTestRunner模块

pip install HTMLTestRunner

 代码如下

import unittest
from HTMLTestRunner import HTMLTestRunner


if __name__ == '__main__':
    # 识别指定目录下所有以test开头的文件以及文件中的用例,并将用例自动添加到测试套中
    test_cases_dir = "./test_cases/"
    suite = unittest.defaultTestLoader.discover(test_cases_dir)

    with open("./report.html", "w", encoding="utf-8") as report:
        runner = HTMLTestRunner.HTMLTestRunner(
            stream=report,
            title='自动化测试报告',
            description='执行全量用例'
        )
        runner.run(suite)

执行结果如下

 报告界面如下

原文地址:https://www.cnblogs.com/testlearn/p/14425753.html