Plugin for python's commitizen, which uses KPN commit rules to bump versions, update files and generate changelogs.
<PREFIX> <SUBJECT> (#<ISSUE_ID>)
<LONG_DESCRIPTION>
Prefix | SemVer relation | Description |
---|---|---|
FIX |
PATCH |
Backwards compatible change that fixes something |
OPT |
PATCH |
Other changes like refactors, docs, which are backwards compatible |
NEW |
MINOR |
New functionality |
BREAK |
MAJOR |
Breaking changes |
NEW: Add login screen (#MY-123)
Install globally in your system
python -m pip install --user cz-kpn
Or add cz-kpn
to your project:
poetry add cz-kpn --group dev
Answer the questions appearing in:
cz init
Just run:
cz bump
cz commit
or the shortcut
cz c
cmd="cz -n cz_kpn commit"
docker run --rm -it -v $(pwd):/app kpnnl/cz-kpn:3.2.9 $cmd
note: gif is outdated
This command is useful for newcomers, or when you don't remember the meaning of each change type. It will display a prompt which will guide the user in the commit creation.
cz commit
git cz commit
Automatic version bump with changelog generation.
cz bump --changelog
Note: The --changelog
flag is not required if update_changelog_on_bump = true
If you don't want to generate a tag and bump the version, run:
cz changelog
This will create a changelog with unreleased commits, alternatively, you can run
cz changelog --incremental
to add only the missing changes. This is useful if you have manually modified your changelog.
This command will tell you if there are any valid or invalid commit messages in the given range.
You can also add it to .pre-commit
hooks or manually as a git hook.
More info in commitizen website.
cz check --rev-range ugnu348hg84hg84g..j8fj84g84h84hg83h2392
Add to the configuration the commit_url
parameter, using $COMMIT_REV
as
variable, you can take a look at this project's .cz.toml as an example
[tool.commitizen]
...
commit_url = "https://YOUR_DOMAIN/projects/YOUR_GROUP/repos/YOUR_PROJECT/commits/$COMMIT_REV"
The recommendation is to run cz init
which will help you create the
right configuration and file.
You can also add manually to your pyproject.toml
or create a .cz.toml
file with:
[tool.commitizen]
name = "cz_kpn"
version = "<YOUR_CURRENT_VERSION>"
version_files = [
"src/__version__.py"
]
slack_channel = "ddci-notifications"
cz --help
Contents:
$ cz --help
Commitizen is a cli tool to generate conventional commits.
For more information about the topic go to https://conventionalcommits.org/
options:
-h, --help show this help message and exit
--debug use debug mode
-n NAME, --name NAME use the given commitizen (default: cz_conventional_commits)
-nr NO_RAISE, --no-raise NO_RAISE
comma separated error codes that won't rise error, e.g: cz -nr 1,2,3 bump. See codes at
https://commitizen-tools.github.io/commitizen/exit_codes/
commands:
{init,commit,c,ls,example,info,schema,bump,changelog,ch,check,version}
init init commitizen configuration
commit (c) create new commit
ls show available commitizens
example show commit example
info show information about the cz
schema show commit schema
bump bump semantic version based on the git log
changelog (ch) generate changelog (note that it will overwrite existing file)
check validates that a commit message matches the commitizen schema
version get the version of the installed commitizen or the current project (default: installed commitizen)
Read Contributing guide
name: Bump version and generate changelog
on:
push:
branches:
- main
jobs:
bump-version:
if: "!startsWith(github.event.head_commit.message, 'BUMP:')"
runs-on: ubuntu-latest
name: "Bump version and create changelog with commitizen"
steps:
- name: Check out
uses: actions/checkout@v3
with:
fetch-depth: 0
token: ${{ secrets.PERSONAL_ACCESS_TOKEN }}
- name: Create bump and changelog
uses: commitizen-tools/commitizen-action@master
with:
github_token: ${{ secrets.PERSONAL_ACCESS_TOKEN }}
changelog_increment_filename: body.md
extra_requirements: "cz-kpn"
- name: Release
uses: softprops/action-gh-release@v1
with:
body_path: "body.md"
tag_name: ${{ env.REVISION }}
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
Read more in commitizen docs