Skip to content

SONAR-23561 Remove Artifact Build Number from Helm releases #78

SONAR-23561 Remove Artifact Build Number from Helm releases

SONAR-23561 Remove Artifact Build Number from Helm releases #78

Workflow file for this run

on:
pull_request:
types: [opened, synchronize, reopened]
# workflow_dispatch:
# inputs:
# version:
# description: "Version of the release"
# required: true
# buildNumber:
# description: "Build number of the release"
# required: true
name: Release
jobs:
release:
runs-on: ubuntu-latest
permissions:
id-token: write
contents: write
steps:
- id: secrets
uses: SonarSource/[email protected]
with:
secrets: |
development/artifactory/token/{REPO_OWNER_NAME_DASH}-promoter access_token | artifactory_access_token;
development/kv/data/slack webhook | slack_webhook_url;
- uses: SonarSource/[email protected]
with:
jfrogAccessToken: ${{ fromJSON(steps.secrets.outputs.vault).artifactory_access_token }}
- name: Checkout
uses: actions/checkout@v3
- name: Fetch history
run: git fetch --prune --unshallow
# - name: Promote
# run: jfrog rt build-promote --status released "${{ github.event.repository.name }}" "${{ github.event.inputs.buildNumber }}" sonarsource-helm-releases
- name: Create local repository directory
id: local_repo
run: echo "dir=$(mktemp -d repo.XXXXXXXX)" >> "$GITHUB_OUTPUT"
- uses: SonarSource/gh-action_release/download-build@v5
with:
local-repo-dir: ${{ steps.local_repo.outputs.dir }}
remote-repo: sonarsource-helm
build-number: "3762"
exclusions: "*.md5,*.sha1,*.sha256,*.sha512"
- name: Check resulting files
run: ls -l ${{ steps.local_repo.outputs.dir }}
- name: Untar the downloaded charts
run: |
cd ${{ steps.local_repo.outputs.dir }}
for file in *.tgz; do tar -xzf "$file" && rm "$file"; done
find . -type f \( -name "*.md5" -o -name "*.sha1" -o -name "*.sha256" -o -name "*.asc" \) -exec rm -rf {} \;
cd ..
- name: Set up helm
uses: azure/setup-helm@v1
with:
version: v3.7.0
- name: Remove the build number from the charts' versions and re-package the helm charts
run: |
SQ_CHART="sonarqube"
SQ_DCE_CHART="sonarqube-dce"
cd ${{ steps.local_repo.outputs.dir }}
# Remove the build number if SQ_CHART is present
if [ -d "$SQ_CHART" ]; then
sed -i '/^version:/ {s/\(^version: [0-9]*\.[0-9]*\.[0-9]*\)\+.*/\1/;}' $SQ_CHART/Chart.yaml
helm package $SQ_CHART
rm -rf $SQ_CHART
fi
# Remove the build number if SQ_DCE_CHART is present
if [ -d "$SQ_DCE_CHART" ]; then
sed -i '/^version:/ {s/\(^version: [0-9]*\.[0-9]*\.[0-9]*\)\+.*/\1/;}' $SQ_DCE_CHART/Chart.yaml
helm package $SQ_DCE_CHART
rm -rf $SQ_DCE_CHART
fi
cd ..
- name: Check resulting files
run: ls -l ${{ steps.local_repo.outputs.dir }}
# - name: Upload binaries to release # Here I can remove the build number.
# uses: svenstaro/upload-release-action@v2
# with:
# repo_token: ${{ secrets.GITHUB_TOKEN }}
# file_glob: true
# file: ${{ steps.local_repo.outputs.dir }}/*
# tag: ${{ github.event.inputs.version }}
# overwrite: true
# - name: Configure Git
# run: |
# git config user.name "$GITHUB_ACTOR"
# git config user.email "[email protected]"
# - name: Release to GitHub
# uses: ./.github/actions/helm-index
# env:
# CR_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
# with:
# repository-name: "${{ github.event.repository.name }}"
# package-path: ${{ steps.local_repo.outputs.dir }}
# release-name: "${{ github.event.inputs.version}}"
# - name: Notify failures on Slack
# if: failure()
# uses: Ilshidur/[email protected]
# env:
# SLACK_WEBHOOK: ${{ fromJSON(steps.secrets.outputs.vault).slack_webhook_url }}
# SLACK_CHANNEL: team-sonarqube-build
# with:
# args: "Helm Chart Release failed, see the logs at https://github.com/SonarSource/helm-chart-sonarqube/actions"