Release #1
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
name: "Release" | |
permissions: | |
contents: read | |
on: | |
workflow_dispatch: | |
inputs: | |
version: | |
description: tag the latest commit on main with the given version (prefixed with v) | |
required: true | |
jobs: | |
quality-gate: | |
environment: release | |
runs-on: ubuntu-20.04 | |
steps: | |
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 #v4.1.1 | |
- name: Check if tag already exists | |
# note: this will fail if the tag already exists | |
run: | | |
[[ "${{ github.event.inputs.version }}" == v* ]] || (echo "version '${{ github.event.inputs.version }}' does not have a 'v' prefix" && exit 1) | |
git tag ${{ github.event.inputs.version }} | |
- name: Check static analysis results | |
uses: fountainhead/action-wait-for-check@297be350cf8393728ea4d4b39435c7d7ae167c93 # v1.1.0 | |
id: static-analysis | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
# This check name is defined as the github action job name (in .github/workflows/validations.yaml) | |
checkName: "Static analysis" | |
ref: ${{ github.event.pull_request.head.sha || github.sha }} | |
- name: Check unit test results | |
uses: fountainhead/action-wait-for-check@297be350cf8393728ea4d4b39435c7d7ae167c93 # v1.1.0 | |
id: unit | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
# This check name is defined as the github action job name (in .github/workflows/validations.yaml) | |
checkName: "Unit tests" | |
ref: ${{ github.event.pull_request.head.sha || github.sha }} | |
- name: Check integration test results | |
uses: fountainhead/action-wait-for-check@297be350cf8393728ea4d4b39435c7d7ae167c93 # v1.1.0 | |
id: integration | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
# This check name is defined as the github action job name (in .github/workflows/validations.yaml) | |
checkName: "Integration tests" | |
ref: ${{ github.event.pull_request.head.sha || github.sha }} | |
- name: Check snapshot build | |
uses: fountainhead/action-wait-for-check@297be350cf8393728ea4d4b39435c7d7ae167c93 # v1.1.0 | |
id: snapshot | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
# This check name is defined as the github action job name (in .github/workflows/validations.yaml) | |
checkName: "Build snapshot artifacts" | |
ref: ${{ github.event.pull_request.head.sha || github.sha }} | |
- name: Quality gate | |
if: steps.static-analysis.outputs.conclusion != 'success' || steps.unit.outputs.conclusion != 'success' || steps.integration.outputs.conclusion != 'success' || steps.snapshot.outputs.conclusion != 'success' | |
run: | | |
echo "Static Analysis Status: ${{ steps.static-analysis.conclusion }}" | |
echo "Unit Test Status: ${{ steps.unit.outputs.conclusion }}" | |
echo "Integration Test Status: ${{ steps.integration.outputs.conclusion }}" | |
echo "Build snapshot artifacts Status: ${{ steps.snapshot.outputs.conclusion }}" | |
false | |
release: | |
needs: [quality-gate] | |
runs-on: ubuntu-20.04 | |
permissions: | |
contents: write | |
packages: write | |
# required for goreleaser signs section with cosign | |
id-token: write | |
steps: | |
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 #v4.1.1 | |
with: | |
fetch-depth: 0 | |
- name: Bootstrap environment | |
uses: ./.github/actions/bootstrap | |
- name: Tag release | |
run: | | |
git config --global user.name "anchoreci" | |
git config --global user.email "[email protected]" | |
git tag -a ${{ github.event.inputs.version }} -m "Release ${{ github.event.inputs.version }}" | |
git push origin --tags | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build & publish release artifacts | |
run: make ci-release | |
env: | |
# for creating the release (requires write access to packages and content) | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- uses: 8398a7/action-slack@28ba43ae48961b90635b50953d216767a6bea486 #v3.16.2 | |
continue-on-error: true | |
with: | |
status: ${{ job.status }} | |
fields: repo,workflow,action,eventName | |
text: "A new Syft release has been published: https://github.com/anchore/syft/releases/tag/${{ github.event.inputs.version }}" | |
env: | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_TOOLBOX_WEBHOOK_URL }} | |
if: ${{ success() }} |