Using Calendar Versioning (CalVer)¶
Calendar Versioning (CalVer) is a versioning scheme that uses a date-based version number.
For this example, we will use the following format: YYYY.MM.DD.patch. It will yield numbers like:
2022.2.1for the first patch of February 1, 20222022.2.1.1for the second patch of February 1, 2022
Initial configuration¶
.bumpversion.toml
[tool.bumpversion]
current_version = "2024.3.1.4"
parse = """(?x) # Verbose mode
(?P<release> # The release part
(?:[1-9][0-9]{3})\\. # YYYY.
(?:1[0-2]|[1-9])\\. # MM.
(?:3[0-1]|[1-2][0-9]|[1-9]) # DD
)
(?:\\.(?P<patch>\\d+))? # .patch, optional
"""
serialize = ["{release}.{patch}", "{release}"]
[tool.bumpversion.parts.release]
calver_format = "{YYYY}.{MM}.{DD}"
You can look up the regular expressions for the CalVer format in the CalVer reference.
Expected behavior¶
- CalVer version components are marked as
always_incrementby default. - When bumping a version, you specify which component to increment. It is called the target component.
- When bumping a version, the components marked as
always_incrementare incremented first. - If an
always_incrementcomponent’s value changed, its dependent components are marked for reset to their default values. - If the target component is in the set of components marked for reset, the target component is reset to its default value.
- If the target component is not in the set of components marked for reset, the target component is incremented and its dependent components are reset to their default values.
Bumping the release resets the patch part¶
When you bump the calendar version, the patch is reset to 0 even if the release did not change.
Bumping the release resets patch
$ date -I
2024-03-1
$ bump-my-version show-bump
2024.3.1.4 ── bump ─┬─ release ─ 2024.3.1
╰─ patch ─── 2024.3.1.5
The next day:
Bumping the release resets patch, the next day
$ date -I
2024-03-2
$ bump-my-version show-bump
2024.3.1.4 ── bump ─┬─ release ─ 2024.3.2
╰─ patch ─── 2024.3.2
The result of a bump to patch depends on the date¶
Calendar Versioned parts are updated with every bump, regardless of the part being bumped. If you are bumping the version within the same time period (in this example, the same day), the release part will not change. So bumping the patch part will increment the patch part only.
Bumping patch on the same day
$ date -I
2024-03-1
$ bump-my-version show-bump
2024.3.1.4 ── bump ─┬─ release ─ 2024.3.1
╰─ patch ─── 2024.3.1.5
However, if you bump the version on the next day, the release part will also be updated.
Bumping patch on the next day
$ date -I
2024-03-2
$ bump-my-version show-bump
2024.3.1.4 ── bump ─┬─ release ─ 2024.3.2
╰─ patch ─── 2024.3.2