Contributing#
Environment Setup#
pipx
This documentaion uses pipx to
install and manage non-project command line tools like hatch
and
pre-commit
. If you don't already have pipx
installed, make sure to
see their documentation.
If you prefer not to use pipx
, you can use pip
instead.
-
Install hatch
pre-commit
Hatch will attempt to set up pre-commit hooks for you using pre-commit. If you don't already, make sure to install pre-commit as well:
pipx install pre-commit
-
Build the Virtual Environment
-
If you need to, you can link hatch's virtual environment to your IDE. It's located in the
.venv
directory at the root of the project. -
Activate the Virtual Environment
Using Hatch#
Hatch Cheat Sheet#
Command Description | Command | Notes |
---|---|---|
Run Tests | hatch run cov |
Runs tests with pytest and coverage |
Run Formatting | hatch run lint:fmt |
Runs ruff code formatter |
Run Linting | hatch run lint:all |
Runs ruff and mypy linters / type checkers |
Run Type Checking | hatch run lint:typing |
Runs mypy type checker |
Update Requirements Lock Files | hatch run gen:reqs |
Updating lock file using pip-compile |
Upgrade Dependencies | hatch run gen:reqs-update |
Updating lock file using pip-compile and --update flag |
Serve the Documentation | hatch run docs:serve |
Serve the documentation using MkDocs |
Run the pre-commit Hooks |
hatch run lint:precommit |
Runs the pre-commit hooks on all files |
Hatch Explanation#
Hatch is a Python package manager. It's most basic use is as a standardized build-system. However, hatch also has some extra features which this project takes advantage of. These features include virtual environment management and the organization of common scripts like linting and testing. All the operations in hatch take place in one of its managed virtual environments.
Hatch has a variety of environments, to see them simply ask hatch:
Standalone
โโโโโโโโโโโณโโโโโโโโโโณโโโโโโโโโโโโโโโโโโโโโโโโโโโโโณโโโโโโโโโโโโโโ
โ Name โ Type โ Dependencies โ Scripts โ
โกโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฉ
โ default โ virtual โ cookiecutter~=2.4.0 โ cov โ
โ โ โ coverage[toml]>=6.5 โ cov-report โ
โ โ โ pytest โ test โ
โ โ โ โ test-cov โ
โโโโโโโโโโโผโโโโโโโโโโผโโโโโโโโโโโโโโโโโโโโโโโโโโโโโผโโโโโโโโโโโโโโค
โ docs โ virtual โ markdown-exec[ansi]~=1.6.0 โ build โ
โ โ โ mkdocs-material~=9.2.3 โ deploy โ
โ โ โ mkdocstrings~=0.22.0 โ serve โ
โ โ โ mkdocs~=1.5.2 โ โ
โโโโโโโโโโโผโโโโโโโโโโผโโโโโโโโโโโโโโโโโโโโโโโโโโโโโผโโโโโโโโโโโโโโค
โ gen โ virtual โ pip-tools~=7.1.0 โ cov โ
โ โ โ โ cov-report โ
โ โ โ โ release โ
โ โ โ โ reqs โ
โ โ โ โ reqs-update โ
โ โ โ โ test โ
โ โ โ โ test-cov โ
โโโโโโโโโโโผโโโโโโโโโโผโโโโโโโโโโโโโโโโโโโโโโโโโโโโโผโโโโโโโโโโโโโโค
โ lint โ virtual โ mypy>=1.6.1 โ all โ
โ โ โ ruff~=0.1.4 โ fmt โ
โ โ โ โ precommit โ
โ โ โ โ style โ
โ โ โ โ typing โ
โโโโโโโโโโโดโโโโโโโโโโดโโโโโโโโโโโโโโโโโโโโโโโโโโโโโดโโโโโโโโโโโโโโ
That above command will tell you that there are four environments that you can use:
default
docs
gen
lint
Each of these environments has a set of commands that you can run. To see the commands for a specific environment, run:
Standalone
โโโโโโโโโโโณโโโโโโโโโโณโโโโโโโโโโโโโโโโโโโโโโณโโโโโโโโโโโโโ
โ Name โ Type โ Dependencies โ Scripts โ
โกโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฉ
โ default โ virtual โ cookiecutter~=2.4.0 โ cov โ
โ โ โ coverage[toml]>=6.5 โ cov-report โ
โ โ โ pytest โ test โ
โ โ โ โ test-cov โ
โโโโโโโโโโโดโโโโโโโโโโดโโโโโโโโโโโโโโโโโโโโโโดโโโโโโโโโโโโโ
Here we can see that the default
environment has the following commands:
cov
cov-report
test
test-cov
The one that we're interested in is cov
, which will run the tests
for the project.
Since cov
is in the default environment, we can run it without
specifying the environment. However, to run the serve
command in the
docs
environment, we need to specify the environment:
You can see what scripts are available using the env show
command
Standalone
โโโโโโโโณโโโโโโโโโโณโโโโโโโโโโโโโโโโโโโโโโโโโโโโโณโโโโโโโโโโ
โ Name โ Type โ Dependencies โ Scripts โ
โกโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโฉ
โ docs โ virtual โ markdown-exec[ansi]~=1.6.0 โ build โ
โ โ โ mkdocs-material~=9.2.3 โ deploy โ
โ โ โ mkdocstrings~=0.22.0 โ serve โ
โ โ โ mkdocs~=1.5.2 โ โ
โโโโโโโโดโโโโโโโโโโดโโโโโโโโโโโโโโโโโโโโโโโโโโโโโดโโโโโโโโโโ
Committing Code#
This project uses pre-commit to run a set of checks on the code before it is committed. The pre-commit hooks are installed by hatch automatically when you run it for the first time.
This project uses semantic-versioning standards, managed by semantic-release.
Releases for this project are handled entirely by CI/CD via pull requests being
merged into the main
branch. Contributions follow the gitmoji standards
with conventional commits.
While you can denote other changes on your commit messages with gitmoji, the following commit message emoji prefixes are the only ones to trigger new releases:
Emoji | Shortcode | Description | Semver |
---|---|---|---|
๐ฅ | :boom: | Introduce breaking changes. | Major |
โจ | :sparkles: | Introduce new features. | Minor |
๐ | :bug: | Fix a bug. | Patch |
๐ | :ambulance: | Critical hotfix. | Patch |
๐ | :lock: | Fix security issues. | Patch |
Most features can be squash merged into a single commit on a pull-request. When merging multiple commits, they will be summarized into a single release.
If you're working on a new feature, your commit message might look like:
Bug fix commits would look like this:
If you're working on a feature that introduces breaking changes, your commit message might look like:
Other commits that don't trigger a release, but get included in the release notes might look like:
๐ Documentation Update Description
๐ท CI/CD Update Description
๐งช Testing Changes Description
๐ Moving/Renaming Description
โฌ๏ธ Dependency Upgrade Description
Pre-Releases#
semantic-release supports pre-releases. To trigger a pre-release, you
would merge your pull request into an alpha
or beta
branch.
Specific Release Versions#
In some cases you need more advanced control around what kind of release you
need to create. If you need to release a specific version, you can do so by creating a
new branch with the version number as the branch name. For example, if the
current version is 2.3.2
, but you need to release a fix as 1.2.5
, you
would create a branch named 1.2.x
and merge your changes into that branch.
See the semantic-release documentation for more information about branch based releases and other advanced release cases.