-
Notifications
You must be signed in to change notification settings - Fork 54
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Move release logic to a new workflow
- remove steps creating the GitHub release from "build.yaml" workflow. - add steps to tag the main branch with the version tag after an automerge in the "build.yaml" workflow. - create a new GitHub workdlow for handling GitHub release on new tags on main. - modify the python script handling the release to be able to get the release body directly. fixes #380
- Loading branch information
Showing
7 changed files
with
142 additions
and
57 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,9 @@ | ||
name: Build, Test and Release | ||
name: Build, Test, Automerge and Tag | ||
|
||
# This workflow runs on all PR that are targetting the main branch. | ||
# | ||
# It runs the test suite. If the PR is a release PR, it automerges and tags the main branch with | ||
# the corresonding new version. Finally, it retags the container image with latest. | ||
|
||
on: | ||
pull_request_target: | ||
|
@@ -118,7 +123,7 @@ jobs: | |
id: create-tarfile | ||
working-directory: ./chart-verifier | ||
run: | | ||
# check if release file only is included in PR | ||
# create test tarball for the tests | ||
ve1/bin/tar-file --release="test" | ||
|
@@ -187,7 +192,7 @@ jobs: | |
- name: Approve PR | ||
id: approve_pr | ||
if: ${{ steps.check_version_updated.outputs.updated == 'true'}} | ||
uses: hmarr/auto-approve-action@v2 | ||
uses: hmarr/auto-approve-action@v3 | ||
with: | ||
github-token: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
|
@@ -200,21 +205,28 @@ jobs: | |
MERGE_METHOD: squash | ||
MERGE_LABELS: "" | ||
|
||
- name: Check for PR merge | ||
- name: Get master branch sha | ||
id: master_sha | ||
if: ${{ steps.check_version_updated.outputs.updated == 'true'}} | ||
run: | | ||
ve1/bin/check-auto-merge --api-url=${{ github.event.pull_request._links.self.href }} | ||
git fetch | ||
export ORIGIN_MASTER_SHA=$(git rev-parse origin/master) | ||
echo "origin_master_sha=$ORIGIN_MASTER_SHA" >> $GITHUB_OUTPUT | ||
- name: Create the the release | ||
id: create_release | ||
- name: Create release tag | ||
id: create_release_tag | ||
if: ${{ steps.check_version_updated.outputs.updated == 'true'}} | ||
uses: softprops/action-gh-release@v1 | ||
uses: mathieudutour/[email protected] | ||
with: | ||
tag_name: ${{ steps.check_version_in_PR.outputs.PR_version }} | ||
body: ${{ steps.check_version_in_PR.outputs.PR_release_body }} | ||
files: ${{ steps.check_version_in_PR.outputs.PR_tarball_name }} | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
# It is necessary to use a Personal Access Token here rather than the usual GITHUB_TOKEN, as this | ||
# step should trigger the release.yaml workflow, and events (such as tags) triggered by the | ||
# GITHUB_TOKEN cannot create a new workflow run. See: | ||
# https://docs.github.com/en/actions/using-workflows/triggering-a-workflow#triggering-a-workflow-from-a-workflow | ||
# This Personal Access Token belongs to the openshift-helm-charts-bot account. | ||
github_token: ${{ secrets.GH_HELM_BOT_TOKEN }} | ||
custom_tag: ${{ steps.check_version_in_PR.outputs.PR_version }} | ||
tag_prefix: "" | ||
commit_sha: ${{ steps.master_sha.outputs.origin_master_sha }} | ||
|
||
- name: Wait for image build to complete | ||
# Quay is configured to automatically build our image. This waits | ||
|
@@ -250,4 +262,4 @@ jobs: | |
imageReference=quay.io/redhat-certification/chart-verifier | ||
podman pull ${imageReference}:${{ steps.check_version_in_PR.outputs.PR_version }} | ||
podman tag ${imageReference}:${{ steps.check_version_in_PR.outputs.PR_version }} ${imageReference}:latest | ||
podman push ${imageReference}:latest | ||
podman push ${imageReference}:latest |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
name: create release on new tags | ||
|
||
# This workflow is triggered by new version tags (e.g. "1.12.2" without leading "v") on the main | ||
# branch. | ||
# | ||
# Tagging should be automatic after each merged PR release (see the build.yaml workflow). | ||
# Alternatively, this workflow can be triggered by manually creating a tag on the main branch with | ||
# the aforementioned format. Note that the tests are *not* run by this workflow, and that you | ||
# should therefore apply caution before manually tagging the main branch in order to trigger it. | ||
# | ||
# This workflow contains a check that the tag matches the version set in | ||
# ./pkg/chartverifier/version/version_info.json. | ||
# | ||
# In order to recreate a GitHub release and rebuild its associated assets, first the tag needs to | ||
# be manually deleted (e.g `git tag --delete 1.12.2 && git push --delete origin 1.12.2`). The | ||
# GitHub release that was created for this tag automatically turns into a "Draft" release and will | ||
# need to be manually cleaned up, though it doesn't constitute a blocker for this workflow to run. | ||
# Finally, as mentioned above, create a new tag (e.g. `git tag 1.12.2 && git push --tags`) to | ||
# recreate the release. | ||
# | ||
# This workflow builds the tarball, creates the Github release and attaches the tarball to it. | ||
|
||
on: | ||
push: | ||
# Publish semver tags as releases. | ||
tags: '[0-9]+.[0-9]+.[0-9]+' | ||
|
||
jobs: | ||
build-and-release: | ||
name: Create GitHub release | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- name: Checkout repository | ||
uses: actions/checkout@v3 | ||
|
||
- name: Setup Go | ||
uses: actions/setup-go@v4 | ||
with: | ||
go-version-file: go.mod | ||
|
||
- name: Print tag to GITHUB_OUTPUT | ||
id: get_tag | ||
run: | | ||
echo "release_version=${GITHUB_REF#refs/*/}" | tee -a $GITHUB_OUTPUT | ||
- name: Build binary and make tarball | ||
id: build_bin | ||
run: | | ||
make bin | ||
TARBALL_NAME="chart-verifier.tgz-${{ steps.get_tag.outputs.release_version }}.tgz" | ||
tar -zcvf $TARBALL_NAME -C out/ chart-verifier | ||
export TARBALL_PATH=$(realpath $TARBALL_NAME) | ||
echo "tarball_path=$TARBALL_PATH" | tee -a $GITHUB_OUTPUT | ||
- name: Check that the tag matches the current version | ||
id: check_tag_and_version | ||
run: | | ||
release_version=${{ steps.get_tag.outputs.release_version }} | ||
bin_version=$(out/chart-verifier version --as-data | jq -r .version) | ||
if [[ "$release_version" != "$bin_version" ]]; then | ||
echo "Binary version ($bin_version) doesn't match tag ($release_version)" && exit 1 | ||
fi | ||
- name: Set up Python 3.x | ||
uses: actions/setup-python@v2 | ||
with: | ||
python-version: '3.9' | ||
|
||
- name: Set up Python scripts | ||
run: | | ||
# set up python requirements and scripts on PR branch | ||
python3 -m venv ve1 | ||
cd scripts && ../ve1/bin/pip3 install -r requirements.txt && cd .. | ||
cd scripts && ../ve1/bin/python3 setup.py install && cd .. | ||
- name: Generate release body | ||
id: release_body | ||
run: echo "release_body=$(ve1/bin/print-release-body)" | tee -a $GITHUB_OUTPUT | ||
|
||
- name: Create the the release | ||
id: create_release | ||
uses: softprops/action-gh-release@v1 | ||
with: | ||
tag_name: ${{ steps.get_tag.outputs.release_version }} | ||
body: ${{ steps.release_body.outputs.release_body }} | ||
files: ${{ steps.build_bin.outputs.tarball_path }} | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
import sys | ||
|
||
sys.path.append('./scripts/src/') | ||
from release import releasechecker | ||
from utils import utils | ||
|
||
def get_release_body(version, image_name, release_info): | ||
"""Generate the body of the GitHub release""" | ||
body = f"Chart verifier version {version} <br><br>Docker Image:<br>- {image_name}:{version}<br><br>" | ||
body += "This version includes:<br>" | ||
for info in release_info: | ||
if info.startswith("<"): | ||
body += info | ||
else: | ||
body += f"- {info}<br>" | ||
return body | ||
|
||
def main(): | ||
version_info = releasechecker.get_version_info() | ||
release_body = get_release_body(version_info["version"],version_info["quay-image"],version_info["release-info"]) | ||
print(release_body) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters