JaCe is an open-source project that accepts contributions from any individual or organization. Proper credit will be given to contributors by adding their names to the AUTHORS.md file.
The fastest way to start with development is to use nox. If you don't have nox, you can use pipx run nox
to run it without installing, or pipx install nox
. If you don't have pipx (pip for applications), then you can install with pip install pipx
(the only case were installing an application with regular pip is reasonable). If you use macOS, then pipx and nox are both in brew, use brew install pipx nox
.
To use, run nox
. This will lint and test using every installed version of Python on your system, skipping ones that are not installed. You can also run specific jobs:
$ nox -s lint # Lint only
$ nox -s tests # Python tests
$ nox -s docs -- --serve # Build and serve the docs
$ nox -s build # Make an SDist and wheel
Nox handles everything for you, including setting up an temporary virtual environment for each run.
You can set up a development environment by running:
python3 -m venv .venv
source ./.venv/bin/activate
pip install --upgrade pip setuptools wheel
pip install -r requirements-dev.txt
pip install -v -e .
If you have the Python Launcher for Unix, you can instead do:
py -m venv .venv
py -m pip install --upgrade pip setuptools wheel
py -m pip install -r requirements-dev.txt
py -m pip install -v -e .
You should prepare pre-commit, which will help you by checking that commits pass required checks:
pip install pre-commit # or brew install pre-commit on macOS
pre-commit install # Will install a pre-commit hook into the git repo
You can also/alternatively run pre-commit run
(changes only) or pre-commit run --all-files
to check even without installing the hook.
Use pytest to run the unit checks:
pytest
Use pytest-cov to generate coverage reports:
pytest --cov=JaCe
You can build the docs using:
nox -s docs
You can see a preview with:
nox -s docs -- --serve
This project uses pre-commit for all style checking. While you can run it with nox, this is such an important tool that it deserves to be installed on its own. Install pre-commit and run:
pre-commit run -a
to check all files.
Before submitting a pull request, check that it meets the following criteria:
- Pull request with code changes should always include tests.
- If the pull request adds functionality, it should be documented both in the code docstrings and in the official documentation.
- The pull request should have a proper description of its intent and the main changes in the code. In general this description should be used as commit message if the pull request is approved (check point 5. below).
- If the pull request contains code authored by first-time contributors, they should add their names to the AUTHORS.md file.
- Pick one reviewer and try to contact them directly to let them know about the pull request. If there is no feedback in 24h/48h try to contact them again or pick another reviewer.
- Once the pull request has been approved, it should be squash-merged as soon as possible with a meaningful description of the changes. We use the Conventional Commits specification for writing informative and automation-friendly commit messages. The following commit types are accepted:
build
: changes that affect the build system or external dependencieschore
: changes related to the development tools or processci
: changes to our CI configuration files and scriptsdocs
: documentation only changesfeat
: a new featurefix
: a bug fixperf
: a code change that improves performancerefactor
: a code change that neither fixes a bug nor adds a featurestyle
: changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)test
: adding missing tests or correcting existing tests