用例执行完成后,执行结果默认是输出在屏幕上,其实我们可以把结果输出到一个文件中,形成测试报告。
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)
执行结果如下
报告界面如下