news 2026/6/10 17:38:40

Pytest单元测试框架生成HTML测试报告及优化的步骤

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Pytest单元测试框架生成HTML测试报告及优化的步骤

本文主要介绍了Pytest单元测试框架生成HTML测试报告及优化的步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

一、安装插件

要生成html类型的报告,需要使用pytest-html插件,可以在IDE中安装,也可以在命令行中安装。插件安装

的位置涉及到不同项目的使用,这里不再详述,想了解的可自行查询。

IDE中安装

在File>Settings>Project>Project Interpreter界面,点击“ + ”搜索pytest-html即可进行安装。

命令行安装

建议先在命令行中切换到python安装路径“ Lib\site-packages ”目录,再执行安装命令。

1

pip install-U pytest-html

二、生成html报告

先准备一个简单的执行脚本

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

importpytest

deffun(x):

returnx+1

deftest_answer_1():

"""测试断言一"""

assertfun(3)==4

deftest_answer_2():

"""测试断言二"""

assertfun(5)==7

@pytest.mark.parametrize("test_input,expected",[

("3+5",8),

("2+4",6),

pytest.param("6 * 9",42,marks=pytest.mark.xfail),

pytest.param("6 * 6",42,marks=pytest.mark.skip)

])

deftest_mark(test_input,expected):

"""用例集合"""

asserteval(test_input)==expected

if__name__=='__main__':

pytest.main(['-v','--html=report.html','test_08.py'])

生成报告命令pytest --html=报告名称 要执行的脚本文件 ,执行上述脚本查看结果。

report.html:报告名称,记录报告生成时间以及插件版本

Environment:测试环境

Summary:用例统计

Results:测试结果,点击Show all details / Hide all details可以展开结果详情或收缩全部结果

三、使用小技巧

指定路径

通过上述命令运行脚本后可以发现,测试报告保存在项目的根目录下,查找报告比较繁琐。我们可以

在运行命令中指定报告路径pytest -v --html=./outputs/report.html test_08.py,代码执行完成,

可以发现项目根目录下生成了outputs文件,测试报告也在其中。

报告独立

当本地执行完成,想把测试报告分享出去,却发现分享出去的报告打开后样式丢失。因为代码执行完成

会生成assets文件,将CSS保存在了本地。我们可以通过命令将CSS写入HTML中,这样生成的测试报告就能

对外分享了。

1

pytest-v--html=./outputs/report.html--self-contained-html test_08.py

四、报告优化

在实际的工作中,通过上述操作生成的测试报告一般不是我们想要的结果。环境信息通过增减更换成需

要展示的内容、增加用例描述、去掉多余的列等等。这里需要将优化代码写入conftest.py文件,该文件名是固

定的不可更改。

导入引用包

import pytestfrom py._xmlgen import htmlfrom datetime import datetime

修改测试环境

@pytest.mark.parametrizedef pytest_configure(config):config._metadata.pop("JAVA_HOME") # 删除java_homeconfig._metadata["项目名称"] = "引擎自动化" # 添加项目名称config._metadata["接口地址"] = "https://www.example.com/poke" # 添加接口地址

修改用例统计​​​​​​​

@pytest.mark.parametrizedef pytest_html_results_summary(prefix,summary,postfix):prefix.extend([html.p("所属部门:测试组")])prefix.extend([html.p("测试人员:许卫玲")])

修改结果显示​​​​​​​

  1. @pytest.mark.optionalhook

  2. def pytest_html_results_table_header(cells):

  3. cells.insert(1,html.th("Description")) # 表头添加Description

  4. cells.insert(2,html.th("Time",class_="sortable time",col="time"))

  5. cells.pop(-1) # 删除link

  6. @pytest.mark.optionalhook

  7. def pytest_html_results_table_row(report,cells):

  8. cells.insert(1,html.td(report.description)) # 表头对应的内容

  9. cells.insert(2,html.td(datetime.now(),class_="col-time"))

  10. cells.pop(-1) # 删除link

  11. @pytest.mark.hookwrapper

  12. def pytest_runtest_makereport(item,call): # Description取值为用例说明__doc__

  13. outcome = yield

  14. report = outcome.get_result()

  15. report.description = str(item.function.__doc__)

  16. report.nodeid = report.nodeid.encode("utf-8").decode("unicode_escape")

修改完成,重新执行脚本,查看最终效果。

到此这篇关于Pytest单元测试框架生成HTML测试报告及优化的步骤的文章就介绍到这了。

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

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

​​​​​​​

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

Z-Image模型图像质量评估指标:FID、CLIP Score等分析

Z-Image模型图像质量评估指标:FID、CLIP Score等分析 在生成式AI飞速演进的今天,文本到图像(Text-to-Image)技术早已不再是实验室里的概念玩具,而是实实在在驱动内容创作、电商设计和数字艺术的核心引擎。阿里推出的 Z…

作者头像 李华
网站建设 2026/6/10 10:35:25

ToolBlock高级脚本之显示文本

ToolBlock高级脚本之显示文本// 用于存储要在图像上显示的图形标签的列表List<CogGraphicLabel> graphics_label new List<CogGraphicLabel>(); // 建立List// 定义了一个Arial字体&#xff0c;大小为12磅Font mFont1 new Font("Arial", 12); // 字体1…

作者头像 李华
网站建设 2026/6/10 10:24:46

Z-Image-Turbo在智能客服图文回复中的创新应用

Z-Image-Turbo在智能客服图文回复中的创新应用 在今天的智能客服系统中&#xff0c;用户早已不满足于“文字对文字”的机械问答。当客户问出“这款手表戴在手上是什么样子&#xff1f;”、“怎么连接蓝牙耳机&#xff1f;”这类问题时&#xff0c;仅靠语言描述往往难以准确传达…

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

Zotero PDF Translate插件:高效翻译与笔记管理一体化解决方案

Zotero PDF Translate插件&#xff1a;高效翻译与笔记管理一体化解决方案 【免费下载链接】zotero-pdf-translate 支持将PDF、EPub、网页内容、元数据、注释和笔记翻译为目标语言&#xff0c;并且兼容20多种翻译服务。 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-p…

作者头像 李华
网站建设 2026/6/10 11:38:03

PlayCover性能调优终极指南:5个技巧告别Mac游戏卡顿

PlayCover性能调优终极指南&#xff1a;5个技巧告别Mac游戏卡顿 【免费下载链接】PlayCover Community fork of PlayCover 项目地址: https://gitcode.com/gh_mirrors/pl/PlayCover 还在为Mac上玩iOS游戏时的卡顿、延迟和发热问题困扰吗&#xff1f;作为一款强大的iOS应…

作者头像 李华
网站建设 2026/6/10 10:23:16

Android Studio中文界面配置终极指南:三步实现全界面汉化

Android Studio中文界面配置终极指南&#xff1a;三步实现全界面汉化 【免费下载链接】AndroidStudioChineseLanguagePack AndroidStudio中文插件(官方修改版本&#xff09; 项目地址: https://gitcode.com/gh_mirrors/an/AndroidStudioChineseLanguagePack 还在为Andro…

作者头像 李华