Skip to content

liiight/pytest-docs

Repository files navigation

pytest-docs

A pytest plugin that generates documentation of the testing application itself.

PyPI version Python versions Travis CI Black Pepy.tech

Features

Create documentation of your tests. Turns this:

'''This is the module doc'''
import pytest

pytestmark = [
    pytest.mark.module_mark,
    pytest.mark.module_mark_2,
    pytest.mark.pytest_doc(name="Test Docs"),
]


@pytest.mark.class_marker
@pytest.mark.pytest_doc(name="Test Class")
class TestClass:
    '''This is the class doc'''

    @pytest.mark.func_mark_a("foo")
    def test_func_a(self):
        '''This is the doc for test_func_a'''
        assert 1

    @pytest.mark.kwarg_mark(goo="bla")
    def test_func_b(self):
        '''This is the doc for test_func_b'''
        assert 1

To this:

# Test Docs
This is the module doc

**Markers:**
- module_mark
- module_mark_2
- pytest_doc  (name=Test Docs)
## Test Class
This is the class doc

**Markers:**
- pytest_doc  (name=Test Class)
- class_marker
### test_func_a
This is the doc for test_func_a

**Markers:**
- func_mark_a (foo)
### test_func_b
This is the doc for test_func_b

**Markers:**
- kwarg_mark  (goo=bla)

Current supported formats:

  • Markdown
  • reStrcutured text

Why not sphinx?

(More accurately, why not sphinx-autodoc?) Sphinx is an amazing tool that I use and used in other project. To use its autodoc plugin, it need the documented plugin to be importable by the python interperter. Pytest test collection and invocation uses a completely separate mechanism. If you believe that it somehow possible to use sphinx to create pytest documentation, please do not hesitate to contact me.

Requirements

  • Python 3.4, 3.5, 3.6 or 3.7
  • Pytest >= 3.5.0

Installation

You can install "pytest-docs" via pip from PyPI:

$ pip install pytest-docs

Usage

Use --docs [PATH] to create the documentation.

Use --doc-type to select the type (currently supports md and rst)

Use @pytest.mark.pytest_doc(name="Test Class") to override name of element. It'll override name based on the place it is being used (module, class or function).

Note: pytest-docs uses the pytest collection mechanism, so your documentation will be generated according the the usual collection commands used to run the tests.

What's planned ahead

  1. See if anyone is even interested in this
  2. Document fixtures
  3. Document tests and fixtures parametrization
  4. Custom formatters via hooks

Contributing

Contributions are very welcome. Tests can be run with tox, please ensure the coverage at least stays the same before you submit a pull request.

License

Distributed under the terms of the MIT license, "pytest-docs" is free and open source software

Issues

If you encounter any problems, please file an issue along with a detailed description.

This pytest plugin was generated with Cookiecutter along with @hackebrot's cookiecutter-pytest-plugin template.