news 2026/5/12 16:38:26

如何用unittest帮你快速生成自动化测试报告?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何用unittest帮你快速生成自动化测试报告?

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

一直以来很多使用 python+unittest 做自动化测试的的小伙伴都在想,unittest 这个官方库为什么没有直接生成测试报告的方法,自己在网上找的一些生成报告的开源的模块,生成的报告样式大都不太美观,不太受领导待见。为了解决大家的这个需求,于是小编这两天就自己专门写了一个 unittest 生成测试报告的库(unittestreport),现在已经上传到 PyPi,大家可通过 pip 命令去下载,接下来就给大家分享一下,这个库怎么使用!

一、unittestreport 安装

安装命令:

cmd 命令行下输入下面的命令进行安装

pip install unittestreport

二、使用说明

话不多说,给大家介绍怎么使用之前,这边先给大家展示一下报告的效果图

报告效果图:

1、使用案例

看完之后有木有觉得很高大上,喜欢这个风格报告的小伙伴可以赶紧去安装了!不仅生成的测试报告清新美观,使用起来也非常的简单,接下来就和大家来讲讲如何使用,首先我们先来看一个使用案例

import unittest from unittestreport import TestRunner # 第一步:加载测试套件 suite1 = unittest.defaultTestLoader.discover(r"xxx\xxx\cases") # 第二步:创建运行对象,传入测试套件 runner = TestRunner(suite1) # 第三步:执行测试 runner.run()

从上面的案例可以看得出来,使用只需要三步,就可以执行测试用例,并且生成一个漂亮的测试报告!

第一步:收集用例

第二步:使用 unittestteport 中的 TestRunner 创建一个运行对象

第三步:执行测试

2、参数解析

接下来给大家详细的介绍一下 TestRunner 的主要使用参数,用户在创建运行对象的时候,除了传入测试套件,还可以自定义报告的标题、描述等相关信息,详细介绍如下:

class TestRunner(): """unittest运行程序""" def __init__(self, suite: unittest.TestSuite, filename="report.html", report_dir=".", title='测试报告', tester='木森', desc="木森执行测试的报告", templates=1 ): """ 初始化用例运行程序 :param suites: 测试套件 :param filename: 报告文件名 :param report_dir:报告文件的路径 :param title:测试套件标题 :param tester:测试者 :param desc:相关的描述信息 :param templates: 可以通过参数值1或者2,指定报告的样式模板,目前只有两个模板 """

3、其他风格报告的整合

很多小伙伴在之前生成测试报告,使用的比较多的是 BeautifulReport 和 HTMLTestRunnerNew 这两个模块,考虑到方便大家使用,该模块除了可以生成上面展示的测试报告,还可以生成 BeautifulReport 风格的测试报告,以及 HTMLTestRunnerNew 的测试报告(这边还是非常感谢这两个开源模块的作者),那么接下来就给大家说说如何生成这两种风格的报告吧,

(1)BeautifulReport 风格的报告

其实要生成 BeautifulReport 风格的报告,非常简单只需要改一个参数即可,案例及报告效果如下

# 创建运行对象的时候加一个参数templates把值设为2即可 runner = TestRunner(suite1,templates=2)

(2)HTMLTestRunnerNew 风格报告

关于 HTMLTestRunnerNew,小编这边直接把源码整合了进来,导入进来即可使用,使用的参数不变,案例代码及效果图如下:

import unittest from unittestteport import TestRunner,HTMLTestRunner # 第一步:加载测试套件 suite1 = unittest.defaultTestLoader.discover(r"xxx\xxx\cases") # 第二步:创建运行对象,传入测试套件 runner = HTMLTestRunner(stream=open("report.html",'wb'), title='木森的测试报告',) # 第三步:执行测试 runner.run()

三、扩展说明

本模块是小编最近开发出来的第一个版本,还没有经过全面的测试,大家在使用的过程中发现有问题,欢迎找小编提 bug,以便对该模块后续的的优化和修改!

另外该模块还支持多线程执行 unittest 测试用例,关于多线程运行的使用和注意点,后续有时间了再给大家介绍!

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 5:22:17

iOS 抓包工具有哪些?不同类型的抓包工具可以做什么

刚开始做 iOS 开发时,我并没有认真思考过“抓包工具有哪些”这个问题。 原因很简单,能看到接口请求,能验证返回结果,就够了。 但当问题开始只在真机出现,只在部分用户出现,或者只在某些网络环境下出现时&am…

作者头像 李华
网站建设 2026/5/10 6:37:47

C++26新特性抢先体验(Clang 17编译器实战指南)

第一章:C26新特性的演进与Clang 17支持概览C26作为ISO C标准的下一个重要迭代,正处于积极的提案与设计阶段。尽管尚未正式发布,多个核心特性已在WG21委员会中获得初步共识,并逐步被主流编译器前端实验性支持。其中,Cla…

作者头像 李华
网站建设 2026/5/9 6:22:26

【C++游戏引擎性能飞跃指南】:掌握多线程渲染优化的7个黄金法则

第一章:C游戏引擎多线程渲染优化概述现代C游戏引擎在处理复杂场景和高帧率需求时,必须充分利用多核CPU的并行计算能力。多线程渲染作为性能优化的核心手段之一,能够将渲染任务分解为多个可并行执行的子任务,从而显著提升渲染效率。…

作者头像 李华
网站建设 2026/5/12 15:46:16

PyTorch安装教程GPU与TensorFlow 2.9模型转换可行性

PyTorch GPU安装与TensorFlow 2.9模型迁移实战指南 在现代深度学习项目中,开发者常常面临一个现实困境:团队使用的框架不统一。比如,历史系统基于 TensorFlow 构建了大量训练好的模型,而新加入的工程师更习惯使用 PyTorch 进行快速…

作者头像 李华
网站建设 2026/5/10 9:58:21

PyTorch安装教程GPU vs TensorFlow-v2.9性能对比分析

PyTorch安装与GPU配置实战:深度对比TensorFlow-v2.9性能表现 在AI研发一线,我们常面临一个现实问题:刚拿到一块新显卡,满心期待地开始搭建环境,结果却卡在CUDA版本不匹配、驱动冲突或依赖报错上。这种“明明硬件到位&…

作者头像 李华
网站建设 2026/5/10 8:38:33

技术博客配图技巧:展示TensorFlow运行效果图

技术博客配图技巧:展示TensorFlow运行效果图 在撰写深度学习相关的技术文章时,你是否曾遇到这样的尴尬?写完一篇关于模型训练的教程,附上代码后却发现读者反馈:“这段代码在我本地跑不起来”“输出结果和你说的不一样”…

作者头像 李华