Skip to main content

A Sphinx extension providing reports and summaries embedded in documentation pages.

Project description

Sourcecode on GitHub Sourcecode License Documentation Documentation License
PyPI PyPI - Status PyPI - Python Version
GitHub Workflow - Build and Test Status Libraries.io status for latest release Codacy - Quality Codacy - Coverage Codecov - Branch Coverage

Sphinx Reports

The Sphinx extension sphinx_reports offers a set of directives to integrate reports and summaries into the documentation generated by Sphinx.

Supported format reports are:

  • ✅🚧 Unit Test summaries (by pytest)
    • ✅ Summary page (displaying unittest.xml)
    • 🚧 Show logging, output and error messages.
  • 🚧 Code coverage (by Coverage.py)
    • ✅ Summary page (displaying coverage.json)
    • 🚧 Individual Sphinx documents per package/module
    • 🚧 Highlighted source code with syntax highlighting and coverage highlighting
  • 🚧 Documentation coverage
    • ✅ Summary page (displaying data from """docstr_coverage""")
    • ❓ Additionally support interrogate as data source.
    • 🚧 Individual Sphinx documents per package/module
    • 🚧 Highlighted source code with syntax highlighting and coverage highlighting
  • 🚧 Package Dependencies
    • 🚧 Summary page (displaying requirements.txt)

Extension Configuration

This README demonstrates a quick and minimal configuration for the Sphinx extension and it's provided directives. See the sphinx-reports documentation for more details.

At first, add the extension name to the list of extensions in conf.py, so the extension is loaded by Sphinx.

# Sphinx extensions
extensions = [
  # ...
  "sphinx_reports",
]

Each report directive might require an individual configuration, therefore see the next sections for details.

Unittest Report Summary

The Unittests Report collects the success or failure of unittests. The results are typically stored in an XML file, which can be read by sphinx-reports. After reading the structure of testsuites and testcases, the report can be visualized. The user

Unitest Summary Page

This is a quick and minimal configuration for the unittest summary directives. See the unittest documentation for more details.

Quick Configuration - Step-by-Step
  1. Configure one or more coverage analysis reports in conf.py by adding a new 'section' defining some configuration variables. Each unittest report is identified by an ID, which is later referred to by the report directive. Here, the ID is called src (dictionary key). Each unittest report needs 1 configuration entry:

    • xml_report - The unittest report as XML file as generated by pytest.
    report_unittest_testsuites = {
      "src": {
        "xml_report": "../report/unit/unittest.xml"
      }
    }
    
  2. Add the unittest-summary directive into your Restructured Text (ReST) document.

    • reportid - The ID used in conf.py to describe a report.
    .. report:unittest-summary::
       :reportid: src
    

Code Coverage Summary

Code Coverage checks if a source code was used during execution. Usually, testcases are run by a testcase execution framework like pytest, which also offers to instrument the code for code coverage collection using the pytest-cov plugin. For Python, coverage collection is usually based on Coverage.py, which supports statement and branch coverage collection either as XML or JSON files. sphinx-reports can visualize a code coverage summary from JSON files.

Code Coverage Summary Page

This is a quick and minimal configuration for the code coverage directives. See the code coverage documentation for more details.

Quick Configuration - Step-by-Step
  1. Configure one or more coverage analysis reports in conf.py by adding a new 'section' defining some configuration variables. Each analysis report is identified by an ID, which is later referred to by the report directive. Here, the ID is called src (dictionary key). Each analysis report needs 4 configuration entries:

    • name - Name of the Python package[^1].
    • json_report - The code coverage report as JSON file as generated by Coverage.py.
    • fail_below - An integer value in range 0..100, for when a code coverage is considered FAILED.
    • levels - A predefined color pallet name or a dictionary of coverage limits, their description and CSS style classes.
    # ==============================================================================
    # Sphinx-reports - CodeCov
    # ==============================================================================
    report_codecov_packages = {
      "src": {
        "name":        "myPackage",
        "json_report": "../report/coverage/coverage.json",
        "fail_below":  80,
        "levels":      "default"
      }
    }
    
  2. Add the code-coverage directive into your Restructured Text (ReST) document.

    • reportid - The ID used in conf.py to describe a Python package.
    .. report:code-coverage::
       :reportid: src
    

Documentation Coverage Summary

Documentation Coverage counts how many publicly accessible members are documented using a Python doc-string. Based on the count of possibly documented public members and the actual number of non-empty doc-strings, a percentage of documentation coverage can be computed.

Documentation coverage is a measure of code quality, which expresses how well documented (completeness or documentation, but not necessarily quality/helpfulness of documentation) source code is. Well documented code helps to use and maintain the existing code base. It also allows for automated documentation generation.

Documentation Coverage Summary Page

This is a quick and minimal configuration for the documentation coverage directives. See the documentation coverage documentation for more details.

Quick Configuration - Step-by-Step
  1. Configure one or more Python packages for documentation coverage analysis in conf.py by adding a new 'section' defining some configuration variables. Each package is identified by an ID, which is later referred to by the report directive. Here, the ID is called src (dictionary key). Each package needs 4 configuration entries:

    • name - Name of the Python package[^1].
    • directory - The directory of the package to analyze.
    • fail_below - An integer value in range 0..100, for when a documentation coverage is considered FAILED.
    • levels - A predefined color pallet name or a dictionary of coverage limits, their description and CSS style classes.
    # ==============================================================================
    # Sphinx-reports - DocCov
    # ==============================================================================
    report_doccov_packages = {
      "src": {
        "name":       "myPackage",
        "directory":  "../myPackage",
        "fail_below": 80,
        "levels":     "default"
      }
    }
    
  2. Add the doc-coverage directive into your Restructured Text (ReST) document.

    • reportid - The ID used in conf.py to describe a Python package.
    .. report:doc-coverage::
       :reportid: src
    

Package Dependencies

🚧 In planning phase 🚧

Contributors

License

This Python package (source code) is licensed under Apache License 2.0.
The accompanying documentation is licensed under Creative Commons - Attribution-4.0 (CC-BY 4.0).


SPDX-License-Identifier: Apache-2.0

[^1]: Toplevel Python packages can reside in a directory not matching the package name. This is possible because the toplevel package name is set in the package installation description. This is not good practice, but possible and unfortunately widely used. E.g. src as directory name.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sphinx_reports-0.10.0.tar.gz (34.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sphinx_reports-0.10.0-py3-none-any.whl (42.3 kB view details)

Uploaded Python 3

File details

Details for the file sphinx_reports-0.10.0.tar.gz.

File metadata

  • Download URL: sphinx_reports-0.10.0.tar.gz
  • Upload date:
  • Size: 34.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for sphinx_reports-0.10.0.tar.gz
Algorithm Hash digest
SHA256 2e14f72e94037a00cae2a5e85719af3ff9c455ad4b840464129fa75a8c3bf543
MD5 db2faacd8d9373b4b661b62c63823422
BLAKE2b-256 f82e1b132a3ba92a309e8d54adc38c78c6d399dc1997be10101a334ff2f31592

See more details on using hashes here.

File details

Details for the file sphinx_reports-0.10.0-py3-none-any.whl.

File metadata

File hashes

Hashes for sphinx_reports-0.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8f5319dc672cff27f85e3533f0056af1ff84099f7fac7d821c3a41d6ca844bd5
MD5 a6d9b20c6a112d403abc699c865696d2
BLAKE2b-256 5dc1a60bfef3a99ef8cfd039febf5afa17b0d43d2d751084bc90b0f10691a1f5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page