pytest plugin for generating HTML reports
Project description
pytest-html is a plugin for py.test that generates a HTML report for the test results.
Requirements
You will need the following prerequisites in order to use pytest-html:
Python 2.6, 2.7, 3.2, 3.3, 3.4, PyPy, or PyPy3
py.test 2.6 or newer
Installation
To install pytest-html:
$ pip install pytest-html
Then run your tests with:
$ py.test --html=report.html
Enhancing reports
You can add change the Environment section of the report by modifying request.config._html.environment from a fixture:
@pytest.fixture(autouse=True)
def _environment(request):
request.config._environment.append(('foo', 'bar'))
You can add details to the HTML reports by creating an ‘extra’ list on the
report object. The following example adds the various types of extras using a
pytest_runtest_makereport
hook, which can be implemented in a plugin or
conftest.py file:
from py.xml import html
def pytest_runtest_makereport(__multicall__, item):
pytest_html = item.config.pluginmanager.getplugin('html')
report = __multicall__.execute()
extra = getattr(report, 'extra', [])
if report.when == 'call':
# always add url to report
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):
# only add additional html on failure
extra.append(pytest_html.extras.html(html.div('Additional HTML')))
report.extra = extra
return report
Resources
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pytest_html-1.6-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 49b98e482d11b4d1b9d32aef829df7025ca4b1b64f47832d2550eda1182940e9 |
|
MD5 | 4b74b371cc4522127e7bdf6fca375d17 |
|
BLAKE2b-256 | 5eb25f08b23a321dddc3d4be75d4ea5fa2a7463ba29d0457704d1382d0dfc2b4 |