Pytest单元测试框架生成HTML测试报告及优化的步骤
作者:Edisonyao 发布时间:2021-07-10 16:49:13
一、安装插件
要生成html类型的报告,需要使用pytest-html插件,可以在IDE中安装,也可以在命令行中安装。插件安装
的位置涉及到不同项目的使用,这里不再详述,想了解的可自行查询。
IDE中安装
在File>Settings>Project>Project Interpreter界面,点击“ + ”搜索pytest-html即可进行安装。
命令行安装
建议先在命令行中切换到python安装路径“ Lib\site-packages ”目录,再执行安装命令。
pip install -U pytest-html
二、生成html报告
先准备一个简单的执行脚本
import pytest
def fun(x):
return x + 1
def test_answer_1():
"""测试断言一"""
assert fun(3) == 4
def test_answer_2():
"""测试断言二"""
assert fun(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)
])
def test_mark(test_input,expected):
"""用例集合"""
assert eval(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中,这样生成的测试报告就能
对外分享了。
pytest -v --html=./outputs/report.html --self-contained-html test_08.py
四、报告优化
在实际的工作中,通过上述操作生成的测试报告一般不是我们想要的结果。环境信息通过增减更换成需
要展示的内容、增加用例描述、去掉多余的列等等。这里需要将优化代码写入conftest.py文件,该文件名是固
定的不可更改。
导入引用包
import pytest
from py._xmlgen import html
from datetime import datetime
修改测试环境
@pytest.mark.parametrize
def pytest_configure(config):
config._metadata.pop("JAVA_HOME") # 删除java_home
config._metadata["项目名称"] = "引擎自动化" # 添加项目名称
config._metadata["接口地址"] = "https://www.example.com/poke" # 添加接口地址
修改用例统计
@pytest.mark.parametrize
def pytest_html_results_summary(prefix,summary,postfix):
prefix.extend([html.p("所属部门:测试组")])
prefix.extend([html.p("测试人员:许卫玲")])
修改结果显示
@pytest.mark.optionalhook
def pytest_html_results_table_header(cells):
cells.insert(1,html.th("Description")) # 表头添加Description
cells.insert(2,html.th("Time",class_="sortable time",col="time"))
cells.pop(-1) # 删除link
@pytest.mark.optionalhook
def pytest_html_results_table_row(report,cells):
cells.insert(1,html.td(report.description)) # 表头对应的内容
cells.insert(2,html.td(datetime.now(),class_="col-time"))
cells.pop(-1) # 删除link
@pytest.mark.hookwrapper
def pytest_runtest_makereport(item,call): # Description取值为用例说明__doc__
outcome = yield
report = outcome.get_result()
report.description = str(item.function.__doc__)
report.nodeid = report.nodeid.encode("utf-8").decode("unicode_escape")
修改完成,重新执行脚本,查看最终效果。
作者:Sweettesting —— 半醉半醒半浮生
出处:http://www.cnblogs.com/Sweettesting/
到此这篇关于Pytest单元测试框架生成HTML测试报告及优化的步骤的文章就介绍到这了,更多相关Pytest生成HTML测试报告内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
来源:https://www.cnblogs.com/Sweettesting/p/15843803.html


猜你喜欢
- 问题是:输入一个数字,按照指定要求逆序输出该数字,很简单,下面是实现:#!usr/bin/env python#encoding:utf-8
- 0.前言Telnet协议属于TCP/IP协议族里的一种,对于我们这些网络攻城狮来说,再熟悉不过了,常用于远程登陆到网络设备进行操作,但是,它
- 本文介绍了网页运行代码框(runCode), 复制代码框(copyCode), 保存代码框(saveCode),的实现方法。javascri
- 在对MySQL数据库进行迁移的时候,有时候也需要迁移源数据库内的用户与权限。对于这个迁移我们可以从mysql.user表来获取用户的相关权限
- PHPMailer是一个封装好的PHP邮件发送类,支持发送HTML内容的电子邮件,以及可以添加附件发送,并不像PHP本身mail()函数需要
- 利用图标工具(有很多)制作图标文件(favicon.ico)上传到网站所在的服务器的根目录下,这个文件必须是16*16大小的图标文件。当然,
- 一、概述OLAP的系统(即Online Aanalyse Process)一般用于系统决策使用。通常和数据仓库、数据分析、数据挖掘等概念联系
- 题目描述682. 棒球比赛你现在是一场采用特殊赛制棒球比赛的记录员。这场比赛由若干回合组成,过去几回合的得分可能会影响以后几回合的得分。比赛
- 1. 安装pip3yum install python34-pip2. 安装python34develyum install python3
- MSSQL随机数 MSSQL有一个函数CHAR()是将int(0-255) ASCII代码转换为字符。那我们可以使用下面MS SQL语句,可
- 基本说明pyc 文件是 Python 编译过的字节码文件。当你运行一个 Python 程序时,Python 解释器首先将源代码(通常是 .p
- vue实现菜单切换,点击菜单导航切换不同的内容以及为当前点击的选项添加样式,或者组件。method里: css:html代码:&l
- 可以利用in运算符来进行判断,如果在指定的序列中找到值返回True,否则返回False。运算符not in表示如果在指定的序列中没有找到值返
- 一 介绍 在笔者支持业务过程中,经常遇到开发咨询replace into 的使用场景以及注意事项,这里做个总结。从功能原理,性能
- spyder快捷键与python符号化输出spyder快捷键1、F5执行当前文件2、F9执行选中的部分3、Tab预加载以该字母为首的变量名例
- function cal_pace(d,h,m,s){ var distance = d; var hours = h;
- Opera, 作为 A-Grade 浏览器,在现在的前端开发中务必支持。它很优秀,很不幸,bug是每个浏览器都不可避免的问题,Opera亦难
- 一、下载1、官网下载2、某度网盘下载链接: https://pan.baidu.com/s/1BgbZH-aFaJ1nwm2PpDeOSQ?
- 一、JavaScript中创建数组的方式(1)使用 Array 构造函数:var arr1 = new Array(); //创建
- Ajax类