Configuring commitizen in a monorepo¶
This tutorial assumes the monorepo layout is designed with multiple components that can be released independently of each other, it also assumes that conventional commits with scopes are in use. Some suggested layouts:
.
├── library-b
│ └── .cz.toml
└── library-z
└── .cz.toml
src
├── library-b
│ └── .cz.toml
└── library-z
└── .cz.toml
Sample .cz.toml
for each component:
# library-b/.cz.toml
[tool.commitizen]
name = "cz_customize"
version = "0.0.0"
tag_format = "${version}-library-b" # the component name can be a prefix or suffix with or without a separator
update_changelog_on_bump = true
# library-z/.cz.toml
[tool.commitizen]
name = "cz_customize"
version = "0.0.0"
tag_format = "${version}-library-z"
update_changelog_on_bump = true
And finally, to bump each of these:
cz --config library-b/.cz.toml bump --yes
cz --config library-z/.cz.toml bump --yes
Changelog per component¶
In order to filter the correct commits for each component, you'll have to come up with a strategy.
For example:
- Trigger the pipeline based on the changed path, which can have some downsides, as you'll rely on the developer not including files from other files
- github actions uses
path
- Jenkins uses
changeset
- Gitlab uses
rules:changes
- github actions uses
- Filter certain pattern of the commit message (recommended)
Example with scope in conventional commits¶
For this example, to include the message in the changelog, we will require commits to use a specific scope. This way, only relevant commits will be included in the appropriate change log for a given component, and any other commit will be ignored.
Example config and commit for library-b
:
[tool.commitizen.customize]
changelog_pattern = "^(feat|fix)\\(library-b\\)(!)?:" #the pattern on types can be a wild card or any types you wish to include
A commit message looking like this, would be included:
fix:(library-b) Some awesome message