news 2026/4/18 10:00:38

Web自动化测试-如何生成高质量的测试报告?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Web自动化测试-如何生成高质量的测试报告?

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

运行了所有测试用例,控制台输入的结果,如果很多测试用例那也不能够清晰快速的知道多少用例通过率以及错误情况。

web自动化测试实战之批量执行测试用例场景: 运行 AllTest.py 文件后得到的测试结果不够专业,无法直观的分析测试结果,我们能否有一个报告直接展示我测试用例运行的测试结果呢。答案是,当然有。

这里我们需要借助第三方库生成HTML格式的测试报告。这里用到的库是 HTMLTestRunner.py / HTMLTestReportCN.py 文件存放路径为 Python安装路径的Lib子文件夹中例如:F:\python3\Lib 如下图,那么当我们将包成功导入到LIb目录下后,我们可以在 AllTest.py 代码开头直接引用我们对应的报告格式包。

备注: HTMLTestRunner.py HTMLTestReportCN.py 一会最后小编会将包打包好推送给大家,都是基于Python3源码都根据python3修改支持使用的,2个包用法是一致,只是展示报告的风格不同一会儿小编会给你介绍大概样式,各位可以喜欢那种就引用哪种。

现在我们的包导入进来,接着我们要做的是生成的报告我们也要创建一个目录存在报告文件例如:'F:\\python3\\report' ,好报告的包导入了,存放报告的目录我们也创建好了,那么我们来看看基于上篇 AllTest.py 执行所有测试用例直接输出到报告怎么写

1、第一种我们引用的 HTMLTestReportCN.py 如下代码

# -*-coding=utf-8-*- import unittest import os, time import HTMLTestReportCN # 用例路径 case_path = 'F:\\python3\\python_code\\test_case_suite' def AllTest(): '''获取所有的测试模块''' suite = unittest.TestLoader().discover( start_dir=os.path.dirname(case_path), pattern='case*.py', top_level_dir=None ) return suite def getNowTime(): '''获取当前的时间''' return time.strftime('%Y-%m-%d-%H-%M-%S', time.localtime(time.time())) def run(): fileName = os.path.join('F:\\python3\\report', getNowTime() + 'report.html') fp = open(fileName,'wb') runner = HTMLTestReportCN.HTMLTestRunner( stream=fp, title=u'项目测试环境单元测试报告', description=u'注:为减少时间人力成本,提高转测质量,特每次对测试环境待发布的代码会对基础功能模块进行单元测试,进一步的提高测试效率,如下为用例执行结果,请查阅!') runner.run(AllTest()) if __name__ == '__main__': run()

注解:在以上完善后的AllTest.py文件中其中导入了os,timemo模块、HTMLTestReportCN 库。getNowTime 方法用来获取当前时间,每一次生成的测试报告如果文件名称一致,由于加上了最新时间信息,便可以根据文件名称确认哪个是最新的测试报告

run 方法用来执行测试套件中的测试用例和生成测试报告。在report 文件夹下生成了最新的测试报告,report的目录如下图所示

2、第二种我们引用的 HTMLTestRunner.py 如下代码

# -*-coding=utf-8-*- import unittest import os, time import HTMLTestRunner # 用例路径 case_path = 'F:\\python3\\python_code\\test_case_suite' def AllTest(): '''获取所有的测试模块''' suite = unittest.TestLoader().discover( start_dir=os.path.dirname(case_path), pattern='case*.py', top_level_dir=None ) return suite def getNowTime(): '''获取当前的时间''' return time.strftime('%Y-%m-%d-%H-%M-%S', time.localtime(time.time())) def run(): fileName = os.path.join('F:\\python3\\report', getNowTime() + 'report.html') fp = open(fileName,'wb') runner = HTMLTestRunner.HTMLTestRunner( stream=fp, title=u'巡服带教测试环境单元测试报告', description=u'注:为减少时间人力成本,提高转测质量,特每次对测试环境待发布的代码会对基础功能模块进行单元测试,进一步的提高测试效率,如下为用例执行结果,请查阅!') runner.run(AllTest()) if __name__ == '__main__': run()

查看报告输出样式

以上就是web自动化批量执行用例之后如果生成报告文件

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

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

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

Temu自养号怎么注册?2026最新注册指南

海外电商平台竞争日益加剧,许多卖家开始探索如何通过Temu自养号来提升产品的曝光率、优化搜索排名并增强店铺信誉。自养号不仅能有效解决传统的高昂成本,还能通过模拟真实用户行为,提高店铺的可信度和运营效率。在本文中,我们将深…

作者头像 李华
网站建设 2026/4/16 19:04:15

基于ai搜索文献的高效文献检索方法与应用研究

做科研的第一道坎,往往不是做实验,也不是写论文,而是——找文献。 很多新手科研小白会陷入一个怪圈:在知网、Google Scholar 上不断换关键词,结果要么信息过载,要么完全抓不到重点。今天分享几个长期使用的…

作者头像 李华
网站建设 2026/4/14 5:56:53

期刊论文投稿不再碰运气!虎贲等考 AI:从选题到见刊全流程开挂

还在为期刊论文投稿反复碰壁?选题不对期刊胃口被秒拒,文献引用格式错乱打回修改,数据图表不达标影响审稿印象,查重降重后语义失真…… 这些难题,虎贲等考 AI 智能写作平台(官网:https://www.aih…

作者头像 李华
网站建设 2026/4/18 6:18:10

ai智能搜索文献:提升文献检索效率与准确性的智能技术应用研究

做科研的第一道坎,往往不是做实验,也不是写论文,而是——找文献。 很多新手科研小白会陷入一个怪圈:在知网、Google Scholar 上不断换关键词,结果要么信息过载,要么完全抓不到重点。今天分享几个长期使用的…

作者头像 李华
网站建设 2026/4/18 9:41:10

硕士毕业通关密码:paperzz 毕业论文功能,重构学术写作新范式

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 毕业论文-AIGC论文检测-AI智能降重-ai智能写作https://www.paperzz.cc/dissertationhttps://www.paperzz.cc/dissertation 对于每一位硕士研究生而言,毕业论文不仅是学术生涯的收官之…

作者头像 李华
网站建设 2026/4/18 7:40:37

学术会议资料管理与共享平台开题报告

学术会议资料管理与共享平台开题报告 一、研究背景 在全球数字化转型加速推进的背景下,学术交流的形式与载体正发生深刻变革。学术会议作为科研工作者分享研究成果、开展学术探讨、建立合作关系的核心场景,其资料的产生、流转与利用模式也面临着新的挑…

作者头像 李华