From baf70decf912a011d02f1a829c9edf9a6a5451b6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafael=20Magalh=C3=A3es?= Date: Tue, 10 Sep 2024 05:33:20 +0100 Subject: [PATCH] docs: Add DR about release workflows refactor (#1521) * draft * Added points * v1.0 * v1.1 - Review sugestions * v1.2 - Review sugestions * v1.3 - Review Sugestions * v2.0 - Review Sugestions * v2.1 - Format * deps * deps * deps --- DEPENDENCIES | 2 +- .../README.md | 85 +++++++++++++++++++ 2 files changed, 86 insertions(+), 1 deletion(-) create mode 100644 docs/development/decision-records/2024-08-28-Release-Workflow-Refactor/README.md diff --git a/DEPENDENCIES b/DEPENDENCIES index cef96161c..14185831f 100644 --- a/DEPENDENCIES +++ b/DEPENDENCIES @@ -671,7 +671,7 @@ maven/mavencentral/org.xmlunit/xmlunit-core/2.9.1, Apache-2.0, approved, #6272 maven/mavencentral/org.xmlunit/xmlunit-placeholders/2.9.1, Apache-2.0, approved, clearlydefined maven/mavencentral/org.yaml/snakeyaml/1.33, Apache-2.0, approved, clearlydefined maven/mavencentral/org.yaml/snakeyaml/2.2, Apache-2.0 AND (Apache-2.0 OR BSD-3-Clause OR EPL-1.0 OR GPL-2.0-or-later OR LGPL-2.1-or-later), approved, #10232 -maven/mavencentral/org.yaml/snakeyaml/2.3, Apache-2.0 AND (Apache-2.0 AND BSD-3-Clause AND EPL-1.0 AND GPL-2.0-or-later AND LGPL-2.1-or-later), restricted, #16046 +maven/mavencentral/org.yaml/snakeyaml/2.3, Apache-2.0 AND (Apache-2.0 OR BSD-3-Clause OR EPL-1.0 OR GPL-2.0-or-later OR LGPL-2.1-or-later), approved, #16046 maven/mavencentral/software.amazon.awssdk/annotations/2.26.27, Apache-2.0, approved, clearlydefined maven/mavencentral/software.amazon.awssdk/annotations/2.27.21, , restricted, clearlydefined maven/mavencentral/software.amazon.awssdk/apache-client/2.26.27, Apache-2.0, approved, clearlydefined diff --git a/docs/development/decision-records/2024-08-28-Release-Workflow-Refactor/README.md b/docs/development/decision-records/2024-08-28-Release-Workflow-Refactor/README.md new file mode 100644 index 000000000..19382c954 --- /dev/null +++ b/docs/development/decision-records/2024-08-28-Release-Workflow-Refactor/README.md @@ -0,0 +1,85 @@ +# Refactor of the Release Workflow + +## Decision + +The existing workflows will be refactored to accommodate the release of bugfix versions as described in [this](../2024-07-18-Improvements-versioning-scheme/README.md) decision record: +- Remove the releases and release/X.Y.Z branches in favor of using just the main branch and tags. +- Change the draft-new-release and publish-new-release to enable bugfix releases + +## Rationale + +Currently, the release of a new version is triggered by the execution of the `draft-new-release` workflow. +The workflow branches from main and checks out into a `release/*` branch where a new commit to represent the releasable state is created. Afterward a PR is created to merge the `release/*` branch into `releases`. +Once the PR is approved and merged, the `publish-new-release` workflow is automaticaly triggered to run the required steps in order to publish all artifacts +in their desired repositories/platforms. With the successful publication of said artifacts, the head of the `releases` branch is merged back into `main` +to keep the integrity of the commit tree. Finally, the current project version is automatically bumped to the next minor version in a new commit to `main` +to kickstart the next development cycle. + +As they stand, the current release workflows don't allow the release of bugfix versions because: +- the `draft-new-release` workflow doesn't create any bugfix branch; +- even if the branch is manually created, merging it to `releases` via PR to trigger the `publish-new-release` workflow, is not possible; +- The `publish-new-release` workflow can't be manually triggered; +- Even if it could be manually triggered, there are steps that shouldn't apply for bugfix releases such as bumping the project version or merging to main; + + +## Approach + +Github Actions Jobs and Step conditionals should be used to make the execution follow the required steps, as follows. + +### Prepare Release workflow logic +- Triggers manually. Input is the version and base ref (should be either commit from main or tag) +- if ref is main + - branches from main into `release/` +- if ref is a tag + - branches from tag into `bugfix/` +- replaces the project default version `(gradle.properties)` with the workflow version input +- replaces openapi spec version +- replaces charts version and README +- commits and pushes to `release/` or `bugfix/` branch +- if new release + - opens PR with new `release/` branch as head and `main/` as base + +Then, a different process takes places if we intend to release a latest version or a bugfix. + +### Case for latest releases +After the prepare release PR is approved, merging into `main` will trigger the `publish-release` workflow where the required publication steps will take place, as shown in [Release workflow logic](#release-workflow-logic). + +### Case for bugfix Releases +After the bugfix branch is created, developers commit the fix or set of fixes to it via PRs. +The release of the bugfix version should be triggered manually through the publishing workflow and executes most of the publication steps of a normal release, except: +- Create any commits to the main branch +- Bump the project version to the next minor version + +### Release workflow logic +- Triggers automatically when prepare release PR is merged into main from `release/*` branch +- Triggers manually only from branches `bugfix/*` + +- Extracts release version from `gradle.properties` +- Triggers release to maven repository by calling `trigger-maven-publish.yaml` +- Triggers docker image publishing by calling `trigger-maven-publish.yaml` +- Releases helm-charts +- Triggers the creation of a Github Tag and Release by calling a new re-usable workflow. +- Publishes to Swaggerhub by calling `publish-swaggerhub.yaml` +- Publishes OpenAPI UI spec to Github Pages by calling `publish-openapi-ui.yml` + +### Github tag and release workflow +A new re-usable workflow should be created that allows for parametrized calls. +Given an `isLatest` parameter, this workflow should: +- Create and push the new tag +- if `isLatest` is set to `true`: + - Updates project version to next version, commits and pushes to main + - if final version, increments to next minor version and adds "-SNAPSHOT" + - if not final version (e.g.-rc1), do not increment +- _(elif set to `false` then skip version increment)_ + +## Other Considerations + +- Keeping `release/*` branches is no longer needed since the tag references the commit on main. +- Release candidates should be handled the same using the same process as a latest release. +- Release workflows should not run on forks. +- Should be possible to trigger the publishing of snapshots manually from main or bugfix branches. +- `draft-new-release` workflow could be named to `draft-release`. +- `publish-new-release` workflow could be named `release`. +- A new `release-bugfix` workflow should be created for releasing bugfixes. +- Commonalities between releasing workflows can be extracted into re-usable workflows and parametrized. +