Skip to content

Managing ACA-Py Read The Docs Documentation

This document describes how to maintain the Read The Docs documentation that is generated from the ACA-Py code base. As the structure of the ACA-Py code evolves, the RTD files need to be regenerated and possibly updated, as described here.

Generating ACA-Py Read The Docs (RTD) documentation

Before you start

To test generate and view the RTD documentation locally, you must install Sphinx and the Sphinx RTD theme. Follow the instructions on the respective pages to install and verify the installation on your system.

Generate Module Files

To rebuild the project and settings from scratch:

cd docs; rm -rf generated; sphinx-apidoc -f -M -o  ./generated ../acapy_agent/ $(find ../acapy_agent/ -name '*tests*'); cd ..

Note that the find command that is used to exclude any of the test python files from the RTD documentation.

Check the git status in your repo to see if the generator updates, adds or removes any existing RTD modules (in the generated folder).

Reviewing the files locally

To auto-generate the module documentation locally run:

cd docs; sphinx-build -b html -a -E -c ./ ./ ./_build; cd ..

Once generated, go into the docs/_build folder and open index.html in a browser. Note that the _build is .gitignore'd and so will not be part of a git push.

If the script does not run at all, you may need to do a pip install -r docs/requirements.txt to update the Sphinx dependencies.

Look for Errors

This is the hard part; looking for errors in docstrings added by devs. Some tips:

  • missing imports (No module named 'async_timeout') can be solved by adding the module to the list of autodoc_mock_imports in the conf.py file in the ACA-Py docs folder.
  • Ignore any errors in .md files
  • Ignore the warnings about including docs/README.md
  • Ignore an dist-package errors

Other than that, please investigate and fix things that you find. If there are fixes, it's usually to adhere to the rules around processing docstrings, and especially around JSON samples.

Checking for missing modules

The file index.rst in the ACA-Py docs folder drive the RTD generation. It picks up all the modules in the source code, starting from the root ../acapy_agent folder. However, some modules are not picked up automatically from the root and have to be manually added to index.rst. To do that:

  • Get a list of all generated modules by running: ls generated | grep "acapy_agent.[a-z]*.rst"
  • Compare that list with the modules listed in the "Subpackages" section of the left side menu in your browser, including any listed below the "Submodules".

If any are missing, you likely need to add them to the index.rst file in the toctree section of the file. You will see there are already several instances of that, notably "connections" and "protocols".

Updating the readthedocs.org site

The RTD documentation is not currently auto-generated, so a manual re-generation of the documentation is still required.

TODO: Automate this when new tags are applied to the repository.