Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pytest-dev/pytest-reportlog
Replacement for the --resultlog option, focused in simplicity and extensibility
https://github.com/pytest-dev/pytest-reportlog
pytest pytest-plugin testing
Last synced: 3 months ago
JSON representation
Replacement for the --resultlog option, focused in simplicity and extensibility
- Host: GitHub
- URL: https://github.com/pytest-dev/pytest-reportlog
- Owner: pytest-dev
- License: mit
- Created: 2019-11-14T20:19:35.000Z (about 5 years ago)
- Default Branch: main
- Last Pushed: 2024-10-22T05:20:21.000Z (3 months ago)
- Last Synced: 2024-10-22T19:35:04.491Z (3 months ago)
- Topics: pytest, pytest-plugin, testing
- Language: Python
- Size: 63.5 KB
- Stars: 90
- Watchers: 11
- Forks: 19
- Open Issues: 5
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG.rst
- License: LICENSE
Awesome Lists containing this project
- awesome-pytest - pytest-reportlog - Report logs into a file as the test session executes. (Plugins)
README
================
pytest-reportlog
================|python| |version| |anaconda| |ci| |black|
.. |version| image:: http://img.shields.io/pypi/v/pytest-reportlog.svg
:target: https://pypi.python.org/pypi/pytest-reportlog.. |anaconda| image:: https://img.shields.io/conda/vn/conda-forge/pytest-reportlog.svg
:target: https://anaconda.org/conda-forge/pytest-reportlog.. |ci| image:: https://github.com/pytest-dev/pytest-reportlog/workflows/test/badge.svg
:target: https://github.com/pytest-dev/pytest-reportlog/actions.. |python| image:: https://img.shields.io/pypi/pyversions/pytest-reportlog.svg
:target: https://pypi.python.org/pypi/pytest-reportlog/.. |black| image:: https://img.shields.io/badge/code%20style-black-000000.svg
:target: https://github.com/ambv/blackReplacement for the ``--resultlog`` option, focused in simplicity and extensibility.
.. note::
This plugin was created so developers can try out the candidate to replace the
`deprecated --resultlog `__ option.If you use ``--resultlog``, please try out ``--report-log`` and provide feedback.
Usage
=====Install ``pytest-reportlog`` as a test requirement in your test environment.
The ``--report-log=FILE`` option writes a file in `JSON lines `__ format as the test session executes.
Each line of the report log contains a self contained JSON object corresponding to a testing event,
such as a collection or a test result report. The file is guaranteed to be flushed after writing
each line, so systems can read and process events in real-time.Each JSON object contains a special key ``$report_type``, which contains a unique identifier for
that kind of report object. For future compatibility, consumers of the file should ignore reports
they don't recognize, as well as ignore unknown properties/keys in JSON objects that they do know,
as future pytest versions might enrich the objects with more properties/keys.Compression
===========Common compression suffixes like `.gz`, `.bz2` and `.xz` will automatically use the requested compression format.
The implementations from the python stdlib are used and must be enabled in the python builds.Example
-------Consider this file:
.. code-block:: python
# content of test_report_example.py
def test_ok():
assert 5 + 5 == 10def test_fail():
assert 4 + 4 == 1::
$ pytest test_report_example.py -q --report-log=log.jsonl
.F [100%]
================================= FAILURES =================================
________________________________ test_fail _________________________________def test_fail():
> assert 4 + 4 == 1
E assert (4 + 4) == 1test_report_example.py:8: AssertionError
------------------- generated report log file: log.jsonl --------------------
1 failed, 1 passed in 0.12sThe generated ``log.jsonl`` will contain a JSON object per line:
::
$ cat log.jsonl
{"pytest_version": "5.2.2", "$report_type": "SessionStart"}
{"nodeid": "", "outcome": "passed", "longrepr": null, "result": null, "sections": [], "$report_type": "CollectReport"}
{"nodeid": "test_report_example.py", "outcome": "passed", "longrepr": null, "result": null, "sections": [], "$report_type": "CollectReport"}
{"nodeid": "test_report_example.py::test_ok", "location": ["test_report_example.py", 0, "test_ok"], "keywords": {"test_ok": 1, "pytest-reportlog": 1, "test_report_example.py": 1}, "outcome": "passed", "longrepr": null, "when": "setup", "user_properties": [], "sections": [], "duration": 0.0, "$report_type": "TestReport"}
{"nodeid": "test_report_example.py::test_ok", "location": ["test_report_example.py", 0, "test_ok"], "keywords": {"test_ok": 1, "pytest-reportlog": 1, "test_report_example.py": 1}, "outcome": "passed", "longrepr": null, "when": "call", "user_properties": [], "sections": [], "duration": 0.0, "$report_type": "TestReport"}
{"nodeid": "test_report_example.py::test_ok", "location": ["test_report_example.py", 0, "test_ok"], "keywords": {"test_ok": 1, "pytest-reportlog": 1, "test_report_example.py": 1}, "outcome": "passed", "longrepr": null, "when": "teardown", "user_properties": [], "sections": [], "duration": 0.00099945068359375, "$report_type": "TestReport"}
{"nodeid": "test_report_example.py::test_fail", "location": ["test_report_example.py", 4, "test_fail"], "keywords": {"test_fail": 1, "pytest-reportlog": 1, "test_report_example.py": 1}, "outcome": "passed", "longrepr": null, "when": "setup", "user_properties": [], "sections": [], "duration": 0.0, "$report_type": "TestReport"}
{"nodeid": "test_report_example.py::test_fail", "location": ["test_report_example.py", 4, "test_fail"], "keywords": {"test_fail": 1, "pytest-reportlog": 1, "test_report_example.py": 1}, "outcome": "failed", "longrepr": {"reprcrash": {"path": "D:\\projects\\pytest-reportlog\\test_report_example.py", "lineno": 6, "message": "assert (4 + 4) == 1"}, "reprtraceback": {"reprentries": [{"type": "ReprEntry", "data": {"lines": [" def test_fail():", "> assert 4 + 4 == 1", "E assert (4 + 4) == 1"], "reprfuncargs": {"args": []}, "reprlocals": null, "reprfileloc": {"path": "test_report_example.py", "lineno": 6, "message": "AssertionError"}, "style": "long"}}], "extraline": null, "style": "long"}, "sections": [], "chain": [[{"reprentries": [{"type": "ReprEntry", "data": {"lines": [" def test_fail():", "> assert 4 + 4 == 1", "E assert (4 + 4) == 1"], "reprfuncargs": {"args": []}, "reprlocals": null, "reprfileloc": {"path": "test_report_example.py", "lineno": 6, "message": "AssertionError"}, "style": "long"}}], "extraline": null, "style": "long"}, {"path": "D:\\projects\\pytest-reportlog\\test_report_example.py", "lineno": 6, "message": "assert (4 + 4) == 1"}, null]]}, "when": "call", "user_properties": [], "sections": [], "duration": 0.0009992122650146484, "$report_type": "TestReport"}
{"nodeid": "test_report_example.py::test_fail", "location": ["test_report_example.py", 4, "test_fail"], "keywords": {"test_fail": 1, "pytest-reportlog": 1, "test_report_example.py": 1}, "outcome": "passed", "longrepr": null, "when": "teardown", "user_properties": [], "sections": [], "duration": 0.0, "$report_type": "TestReport"}
{"exitstatus": 1, "$report_type": "SessionFinish"}record_property
---------------The ``record_property`` fixture allows to log additional information for a test, just like with JUnitXML format.
Consider this test file:.. code-block:: python
def test_function(record_property):
record_property("price", 12.34)
record_property("fruit", "banana")
assert TrueThis information will be recorded in the report JSON objects under the ``user_properties`` key as follows::
..., "user_properties": [["price", 12.34], ["fruit", "banana"]], ...
Note that this nested list construct is just the JSON representation
of a list of tuples (name-value pairs).