Contributing to rCDS

Workflow

Dependency management is done through poetry, and pre-commit linting hooks are maanged with pre-commit. To get started, run poetry install and poetry run pre-commit install.

Tests use pytest, and a Makefile is set up with targets for common operations; to run tests, use make test; to run tests and get an HTML coverage report, use make htmlcov; to lint everything, use either make lint or poetry run pre-commit run -a (make lint will stop executing linters after one failure, while pre-commit will not lint any untracked files).

Note

This is subject to change; we may move the running of these jobs to use tox in the future, but for now make is used for running scripts.

This project uses isort, black, flake8 with flake8-bugbear, and mypy (see the pre-commit configuration); consider setting up editor integrations to ease your development process (particularly with mypy).

If you want a live preview of the docs as you work, you can install sphinx-autobuild into the Poetry virtualenv (poetry run pip install sphinx-autobuild) and run it via poetry run make livebuild.

Git

This project follows Conventional Commits, and uses Angular’s commit types.

Branches should be named prefixed with a type (the same types as used in the commit message) and a short description of the purpose of the branch. Some examples:

feat/brief-description
fix/bug-description