This release process covers the steps to release new major and minor versions for the Kyma Telemetry module.
-
Verify that all issues in the GitHub milestone related to the version are closed.
-
Close the milestone.
-
Create a new GitHub milestone for the next version.
-
In the
telemetry-manager
repository, create a release branch. The name of this branch must follow therelease-x.y
pattern, such asrelease-1.0
.git fetch upstream git checkout --no-track -b {RELEASE_BRANCH} upstream/main git push upstream {RELEASE_BRANCH}
-
Bump the
telemetry-manager/{RELEASE_BRANCH}
branch with the new versions for the dependent images. Create a PR totelemetry-manager/{RELEASE_BRANCH}
with the following changes:- Update Docker images in the
.env
file:- Update the
ENV_IMG
variable, update the tag of thetelemetry-manager
image with the new module version following thex.y.z
pattern. For example,ENV_IMG=europe-docker.pkg.dev/kyma-project/prod/telemetry-manager:1.0.0
. - Update the
DEFAULT_OTEL_COLLECTOR_IMAGE
variable, update the tag of thekyma-otel-collector
image with the new version released from the opentelemetry-collector-components repository. For example,DEFAULT_OTEL_COLLECTOR_IMAGE=europe-docker.pkg.dev/kyma-project/prod/kyma-otel-collector:0.100.0-1.0.0
.
- Update the
- Update
config/manager/kustomization.yaml
:- Update the
newTag
field for thetelemetry-manager
image with the new module version following thex.y.z
pattern, such as1.0.0
.
- Update the
- Update
main.go
:- Update the
version
variable with the new module version following thex.y.z
pattern.
- Update the
make generate
- Run
make generate
to update the images in thesec-scanners-config.yaml
and other files.
- Run
- Update Docker images in the
-
Merge the PR.
-
To make sure that the release tags point to the HEAD commit of the
telemetry-manager/{RELEASE_BRANCH}
branch, rebase the upstream branch into the local branch after the merge was successful.git rebase upstream/{RELEASE_BRANCH} {RELEASE_BRANCH}
-
In the
telemetry-manager/{RELEASE_BRANCH}
branch, create release tags for the HEAD commit.git tag {RELEASE_VERSION}
Replace {RELEASE_VERSION} with the new module version, for example,
1.0.0
. -
Push the tags to the upstream repository.
git push upstream {RELEASE_VERSION}
The {RELEASE_VERSION} tag triggers the GitHub actions Build Image
and Tag Release
. The Build Image
action builds the telemetry-manager
image, tags it with the module version, and pushes it to the production registry. Tag Release
action creates the GitHub release.
-
Once the
Build Image
and theTag Release
GitHub actions succeed, the new GitHub release is available under releases. -
If the
Build Image
or theTag Release
GitHub action fails, re-trigger them by removing the {RELEASE_VERSION} tag from upstream and pushing it again:git push --delete upstream {RELEASE_VERSION} git push upstream {RELEASE_VERSION}
- If the previous release was a bugfix version (patch release) that contains cherry-picked changes, these changes might appear again in the generated change log. If there are redundant entries, edit the release description and remove them.
Every PR's title must adhere to the Conventional Commits specification for an automatic changelog generation. It is enforced by a semantic-pull-request GitHub Action.
Due to the Squash merge GitHub Workflow, each PR results in a single commit after merging into the main development branch. The PR's title becomes the commit message and must adhere to the template:
type(scope?): subject
- feat. A new feature or functionality change.
- fix. A bug or regression fix.
- docs. Changes regarding the documentation.
- test. The test suite alternations.
- deps. The changes in the external dependencies.
- chore. Anything not covered by the above categories (e.g., refactoring or artefacts building alternations).
Beware that PRs of type chore
do not appear in the Changelog for the release. Therefore, exclude maintenance changes that are not interesting to consumers of the project by marking them with chore type:
- Dotfile changes (.gitignore, .github, and so forth).
- Changes to development-only dependencies.
- Minor code style changes.
- Formatting changes in documentation.
The subject must describe the change and follow the recommendations:
- Describe a change using the imperative mood. It must start with a present-tense verb, for example (but not limited to) Add, Document, Fix, Deprecate.
- Start with an uppercase, and not finish with a full stop.
- Kyma capitalization and terminology guides.