一、前言
插件项目地址:https://github.com/pytest-dev/pytest-html
官方文档地址:https://pytest-html.readthedocs.io/en/latest/
二、安装
依赖
直接安装
pip install pytest-html
从源码安装
pip install -e .
三、基本使用
pytest --html=report.html
pytest --html=report.html --self-contained-html
四、深度使用
1. 改变报告样式
pytest --html=report.html --css=自定义的样式文件的路径
示例
-
首先新建一个css文件,入如:report.css data:image/s3,"s3://crabby-images/3a365/3a365bcdf7cb6ac5ac7c39cb44b165809b40294d" alt="在这里插入图片描述" -
打开pytest-html生成的报告,用F12查看标签的相关信息,class,id,标签名等
data:image/s3,"s3://crabby-images/7830b/7830bcbafc76629a1337c5a57835820646c2a9d4" alt="在这里插入图片描述" 3. 先尝试直接通过F12更改报告样式,看是否有效。(当前如果你很会css,可以忽略这个步骤) data:image/s3,"s3://crabby-images/0eb6b/0eb6b56eb78dd7b6d542d54b5e97b31061ccbcf0" alt="在这里插入图片描述"
-
拷贝样式代码到report.css data:image/s3,"s3://crabby-images/63627/63627a87823b3484bdcea517679b667fd661b482" alt="在这里插入图片描述" -
运行测试时,指定该css文件:pytest --html=report.html --css=report.css data:image/s3,"s3://crabby-images/bd836/bd83604aa96b824ed3fb9caad2d2de0911513bf0" alt="在这里插入图片描述" -
再次打开报告,可以看到我们指定的css样式生效了。 data:image/s3,"s3://crabby-images/640fb/640fbe889c2f3756311c8b4349568ea21c91fb8d" alt="在这里插入图片描述"
2. 修改报告标题
默认情况下,pytest-html会使用报告文件名作为报名标题,这里我们可以通过钩子函数pytest_html_report_title 更改报告标题。
def pytest_html_report_title(report):
report.title = "My very own title!"
示例
-
找到项目根目录下的conftest.py文件,往里面粘贴上面的代码,其中标题是可以自定义的。 data:image/s3,"s3://crabby-images/0363d/0363d5fea838fda7fa3937ef98a20487e471b694" alt="在这里插入图片描述" -
重新生成报告就可以看到效果了。 data:image/s3,"s3://crabby-images/7efdd/7efdd518d6b747ccbe73c294e70eaea4db6ff8b9" alt="在这里插入图片描述"
3. 修改Enviroment
环境模块是由 pytest-metadata 插件提供的。有两个钩子函数:pytest_configure ,pytest_sessionfinish
在测试运行前修改环境配置pytest_configure
def pytest_configure(config):
config._metadata["键"] = "值"
在测试运行后修改环境配置pytest_sessionfinish
import pytest
@pytest.hookimpl(tryfirst=True)
def pytest_sessionfinish(session, exitstatus):
session.config._metadata["键"] = "值"
注意:
@pytest.hookimpl(tryfirst=True) 非常重要;- 它可以使得
pytest_sessionfinish 在任何其他插件(包括pytest-html , pytest-metadata )运行前运行; - 如果我们没有增加
@pytest.hookimpl(tryfirst=True) ,就会导致环境表不会按照我们预想的发生变化。
示例
-
在conftest.py文件上增加如下代码 data:image/s3,"s3://crabby-images/f047c/f047c6b543577375858f9722c6778c174ccf202a" alt="在这里插入图片描述" -
重新运行生成报告后,报告如下图所示 data:image/s3,"s3://crabby-images/afdd1/afdd19d3059689d687ca5c20cb85d3292773be7e" alt="在这里插入图片描述"
问题
官方文档这部分功能,没有理解,大家如果搞定了可以给我留言,谢谢啦! data:image/s3,"s3://crabby-images/c88b3/c88b37e5ead3974bdec1c466f462111722874b47" alt="在这里插入图片描述"
4. 修改Summary
我们可以通过钩子函数pytest_html_results_summary 修改summary部分内容。
from py.xml import html
def pytest_html_results_summary(prefix, summary, postfix):
prefix.extend([html.p("追加的内容")])
示例
-
在conftest.py文件上增加如下代码 data:image/s3,"s3://crabby-images/ef65e/ef65e85e3564a59c8507f22ca4338173f71217f4" alt="在这里插入图片描述" -
重新运行生成报告后,报告如下图所示 data:image/s3,"s3://crabby-images/f180d/f180d7e981064c5731c230ca405b50d761754fc2" alt="在这里插入图片描述"
5. 增加额外的内容
我们能通过extra 给报告增加更多的详细信息。以下是我们可以增加的内容。
Type | Example |
---|
Raw HTML | extra.html(‘
Additional HTML
’) | JSON | extra.json({‘name’: ‘pytest’}) | Plain text | extra.text(‘Add some simple Text’) | URL | extra.url(‘http://www.example.com/’) | Image | extra.image(image, mime_type=‘image/gif’, extension=‘gif’) | Image | extra.image(‘/path/to/file.png’) | Image | extra.image(‘http://some_image.png’) |
注意:
Image format | Example |
---|
PNG | extra.png(image) | JPEG | extra.jpg(image) | SVG | extra.svg(image) |
但是我亲自尝试过,直接使用extras.image就可以加载上述类型的图片。上述指定格式显得稍有点多余。
而且注意:官方文档都是写的extra.image 或者 extra.svg , extra没有带s,实际示例中有s,实际使用也需要用extras。这里不知道是不是我理解的有问题,还是官方文档笔误,大家注意一下。
我们可以在conftest.py中通过钩子函数pytest_runtest_makereport 来增加这些额外的内容。
import pytest
@pytest.hookimpl(hookwrapper=True)
def pytest_runtest_makereport(item, call):
pytest_html = item.config.pluginmanager.getplugin("html")
outcome = yield
report = outcome.get_result()
extra = getattr(report, "extra", [])
if report.when == "call":
extra.append(pytest_html.extras.url("http://www.example.com/"))
xfail = hasattr(report, "wasxfail")
if (report.skipped and xfail) or (report.failed and not xfail):
extra.append(pytest_html.extras.html("<div>Additional HTML</div>"))
report.extra = extra
示例1
-
首先修改我们的用例,让用例产生各种类型的数据,方便看效果。 data:image/s3,"s3://crabby-images/84d9e/84d9e47f153b31cec01ac748f5862699554a5d4c" alt="在这里插入图片描述" -
我们在conftest.py文件中增加如下代码
@pytest.hookimpl(hookwrapper=True)
def pytest_runtest_makereport(item, call):
pytest_html = item.config.pluginmanager.getplugin("html")
outcome = yield
report = outcome.get_result()
extra = getattr(report, "extra", [])
if report.when == "call":
extra.append(pytest_html.extras.url("https://www.gitlink.org.cn"))
extra.append(pytest_html.extras.json({"name": "pytest"}))
extra.append(pytest_html.extras.text("这里是xxx自动化测试用例"))
xfail = hasattr(report, "wasxfail")
if (report.skipped and xfail) or (report.failed and not xfail):
extra.append(pytest_html.extras.html(
"<div style='background-color:red;text-align: center;font-size:16px;color:white;'>这条用例xfail 或者 failed</div>"))
extra.append(pytest_html.extras.image("111.gif", mime_type="image/gif", extension="gif"))
extra.append(pytest_html.extras.image("1.bmp"))
extra.append(pytest_html.extras.svg("2.svg"))
extra.append(pytest_html.extras.image("https://www.gitlink.org.cn/api/attachments/389903"))
report.extra = extra
data:image/s3,"s3://crabby-images/fd8dd/fd8dda0c1a57330432c80ad69d88efe62bfe538e" alt="在这里插入图片描述" 3. 运行生成报告后如下图所示 data:image/s3,"s3://crabby-images/8d3aa/8d3aa1e8b78eb2f1bbf61c89896637a940aeb3c3" alt="在这里插入图片描述"
我们还可以给除了html的其他类型来增加name 来改变增加内容的标题。
extra.append(pytest_html.extras.text("some string", name="Different title"))
示例2
- 修改conftest.py中的
pytest_runtest_makereport 的内容
@pytest.hookimpl(hookwrapper=True)
def pytest_runtest_makereport(item, call):
pytest_html = item.config.pluginmanager.getplugin("html")
outcome = yield
report = outcome.get_result()
extra = getattr(report, "extra", [])
if report.when == "call":
extra.append(pytest_html.extras.url("https://www.gitlink.org.cn", name="gitlink"))
extra.append(pytest_html.extras.json({"name": "pytest"}, name="接口响应数据"))
extra.append(pytest_html.extras.text("这里是xxx自动化测试用例", name="文本"))
extra.append(pytest_html.extras.image("1.bmp", name="图片"))
xfail = hasattr(report, "wasxfail")
if (report.skipped and xfail) or (report.failed and not xfail):
extra.append(pytest_html.extras.html(
"<div style='background-color:red;text-align: center;font-size:16px;color:white;'>这条用例xfail 或者 failed</div>"))
report.extra = extra
data:image/s3,"s3://crabby-images/df87e/df87eaea36fef2520784ca74d554ac2e7388c843" alt="在这里插入图片描述"
- 运行生成报告后如下图所示
data:image/s3,"s3://crabby-images/bb5bd/bb5bd3867133fa8c0bf0825057f421b46a3d5ba9" alt="在这里插入图片描述"
我们也可以直接在测试方法中将extra当做一个fixture使用,而不使用上述的钩子函数pytest_runtest_makereport 。
from pytest_html import extras
def test_extra(extra):
extra.append(extras.text("some string"))
示例3
- 在测试函数代码如下:
注意:原先conftest.py中的pytest_runtest_makereport 可以注释掉了。
import pytest
from pytest_html import extras
def test_demo_01(extra):
extra.append(extras.text("这是一条通过的用例", name="测试通过的文本"))
assert 1 == 1
def test_demo_02(extra):
extra.append(extras.json("这是一条失败的用例", name="测试失败的JSON"))
assert True == False
def test_demo_03(extra):
extra.append(extras.html(
"<div style='background-color:red;text-align: center;font-size:16px;color:white;'>这条用例xfail 或者 failed</div>"))
pytest.xfail("这是一条xfail的用例")
def test_demo_04():
pytest.skip("这条用例跳过")
data:image/s3,"s3://crabby-images/634e8/634e8b73e3d605b8e016ef9653d68b3a0a36f7c0" alt="在这里插入图片描述"
- 运行生成报告后如下图所示
data:image/s3,"s3://crabby-images/bfeef/bfeefe7c4288ab3ed890151589576ccedf43f735" alt="在这里插入图片描述"
6. 修改结果表
增加description, Time列,移除Links列
-
首先修改一下测试方法,给部分测试方法增加文档注释 data:image/s3,"s3://crabby-images/ef095/ef09529bd0301906994b3fea18ea6b375f4fcc8d" alt="在这里插入图片描述" -
在conftest.py中增加如下代码
from datetime import datetime
def pytest_html_results_table_header(cells):
"""
处理结果表的表头
"""
cells.insert(2, html.th("Description", class_="sortable desc", col="desc"))
cells.insert(1, html.th("Time", class_="sortable time", col="time"))
cells.pop()
def pytest_html_results_table_row(report, cells):
"""
处理结果表的行
"""
cells.insert(2, html.th(report.description))
cells.insert(1, html.th(datetime.utcnow(), class_="col-time"))
cells.pop()
@pytest.hookimpl(hookwrapper=True)
def pytest_runtest_makereport(item, call):
outcome = yield
report = outcome.get_result()
if str(item.function.__doc__) != "None":
report.description = str(item.function.__doc__)
else:
report.description = "这里是描述信息"
- 运行生成报告后如下图所示
data:image/s3,"s3://crabby-images/44d79/44d7959af5217a964b576a9198486962a2422a0c" alt="在这里插入图片描述"
测试通过的情况下删除所有的单元格
注意:这种情况下,我们在报告中无法看到通过用例的任何信息。 在conftest.py中增加如下代码:
def pytest_html_results_table_row(report, cells):
if report.passed:
del cells[:]
钩子函数pytest_html_results_table_html 修改日志输出和其他HTML
在conftest.py中增加如下代码:
from py.xml import html
def pytest_html_results_table_html(report, data):
if report.passed:
del data[:]
data.append(html.div("这条用例通过啦!", class_="empty log"))
运行后产生的报告如下: data:image/s3,"s3://crabby-images/441e1/441e1f90d52ff1ad651c45f926d997fb86681e67" alt="在这里插入图片描述"
7. 自动收起所有的列
默认情况下,结果表中的所有行都是展开显示的。如下图所示: data:image/s3,"s3://crabby-images/7a513/7a5134bdf466f5940457bcef4417568ce1d9e522" alt="在这里插入图片描述"
我们可以通过在pytest的配置文件pytest.ini中设置来决定是否展开还是收起。
[pytest]
render_collapsed = True
重新运行生成报告后如下图所示: data:image/s3,"s3://crabby-images/ad3ba/ad3ba10994e325bc3f7e4cd16e507a7663f685d5" alt="在这里插入图片描述"
官方文档这里提出的设置查询参数,没有搞明白怎么设置,有搞明白的,欢迎给我留言~ data:image/s3,"s3://crabby-images/cbbbf/cbbbfc362e566959690c464f21dc3aa2bbe40805" alt="在这里插入图片描述"
8. 设置哪些测试结果可见
官方文档这里提出的设置查询参数,没有搞明白怎么设置,有搞明白的,欢迎给我留言~ data:image/s3,"s3://crabby-images/f353a/f353aa9d986c1333f710720f9298999a99e27b2d" alt="在这里插入图片描述"
9. 格式化Duration列
默认情况下,Durations列是用得一个格式化的时间戳,使用的是%S.%f ,%S 是秒%f 是毫秒, 是通过duration_formatter 设置的。目前pytest-html是支持所有的格式化指令的。
但是我们可以在conftest.py文件中对Duration列进行格式化设置。
import pytest
@pytest.hookimpl(hookwrapper=True)
def pytest_runtest_makereport(item, call):
outcome = yield
report = outcome.get_result()
setattr(report, "duration_formatter", "%H:%M:%S.%f")
NOTE: Milliseconds are always displayed with a precision of 2
|