build(deps): bump library/alpine from 3.21.1 to 3.21.2 (#82) #274
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: Continuous Integration Pipeline | |
on: | |
push: | |
branches: | |
- main | |
tags: | |
- "*" | |
pull_request: | |
branches: | |
- main | |
paths-ignore: | |
- "**/*.md" | |
- docs/** | |
- examples/** | |
env: | |
GORELEASER_VERSION: v2.4.8 | |
jobs: | |
lint: | |
name: Lint Code | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
with: | |
show-progress: false | |
- name: Setup Golang | |
uses: actions/setup-go@3041bf56c941b39c61721a86cd11f3bb1338122a # v5.2.0 | |
with: | |
go-version-file: go.mod | |
cache: false | |
- name: Set golangci-lint Cache Key | |
id: create-sha | |
run: | | |
echo "GOLANGCILINT_SHA=$(cat ./tools/GOLANGCI_LINT_VERSION | sha256sum - | awk '{ print $1 }')" >> $GITHUB_ENV | |
- name: Setup golangci-lint Cache | |
uses: actions/cache@1bd1e32a3bdc45362d1e726936510720a7c30a57 # v4.2.0 | |
with: | |
path: | | |
./tools/bin | |
key: ${{ runner.os }}-go-${{ env.GOLANGCILINT_SHA }} | |
restore-keys: | | |
${{ runner.os }}-go-${{ env.GOLANGCILINT_SHA }} | |
- name: Run Lint CI | |
run: make ci-lint GOLANGCI_LINT_MODE="github-actions" | |
test: | |
name: Testing on ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: | |
- ubuntu-latest | |
- macos-latest | |
runs-on: ${{ matrix.os }} | |
env: | |
GOEXPERIMENT: nocoverageredesign | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
with: | |
show-progress: false | |
- name: Setup Golang | |
uses: actions/setup-go@3041bf56c941b39c61721a86cd11f3bb1338122a # v5.2.0 | |
with: | |
go-version-file: go.mod | |
- name: Run Test Coverage | |
run: make ci | |
build: | |
name: Build for Supported Architectures | |
runs-on: ubuntu-latest | |
needs: | |
- lint | |
- test | |
if: github.event_name != 'push' | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
with: | |
show-progress: false | |
- name: Setup Golang | |
uses: actions/setup-go@3041bf56c941b39c61721a86cd11f3bb1338122a # v5.2.0 | |
with: | |
go-version-file: go.mod | |
- name: Setup Goreleaser | |
uses: goreleaser/goreleaser-action@9ed2f89a662bf1735a48bc8557fd212fa902bebf # v6.1.0 | |
with: | |
version: ${{ env.GORELEASER_VERSION }} | |
install-only: true | |
- name: Run Build Multiarchitecture | |
run: make build-multiarch | |
publish-release: | |
runs-on: ubuntu-latest | |
needs: | |
- lint | |
- test | |
if: github.event_name == 'push' | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
with: | |
show-progress: false | |
fetch-depth: 0 | |
- name: Setup Golang | |
uses: actions/setup-go@3041bf56c941b39c61721a86cd11f3bb1338122a # v5.2.0 | |
with: | |
go-version-file: go.mod | |
- name: Setup Goreleaser | |
uses: goreleaser/goreleaser-action@9ed2f89a662bf1735a48bc8557fd212fa902bebf # v6.1.0 | |
with: | |
version: ${{ env.GORELEASER_VERSION }} | |
install-only: true | |
- name: Set Snapshot Release Environment | |
if: github.ref_type == 'branch' | |
run: | | |
echo "SNAPSHOT_RELEASE=1" >> $GITHUB_ENV | |
- name: Run Goreleaser | |
run: make ci-release SNAPSHOT_RELEASE=${SNAPSHOT_RELEASE} | |
env: | |
GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }} | |
- name: Upload Binaries Artifacts | |
uses: actions/upload-artifact@6f51ac03b9356f520e9adb1b1b7802705f340c2b # v4.5.0 | |
with: | |
name: artifacts | |
path: bin/ | |
publish-docker: | |
runs-on: ubuntu-latest | |
needs: | |
- publish-release | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
with: | |
show-progress: false | |
- name: Download Binaries | |
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8 | |
with: | |
name: artifacts | |
path: bin/ | |
- name: Restore Executable Permissions | |
run: | | |
find ./bin/{darwin,linux} -type f -exec chmod +x {} \; | |
- name: Docker Login to GitHub Repository | |
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v3.3.0 | |
with: | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Docker Login to DockerHub | |
uses: docker/login-action@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v3.3.0 | |
with: | |
username: ${{ secrets.BOT_DOCKER_USERNAME }} | |
password: ${{ secrets.BOT_DOCKER_TOKEN }} | |
- name: Setup QEMU | |
run: make docker-setup-multiarch | |
- name: Setup Buildx Context | |
id: buildx | |
uses: docker/setup-buildx-action@6524bf65af31da8d45b59e8c27de4bd072b392f5 # v3.8.0 | |
- name: Build Latest Image | |
run: make ci-docker BUILDX_CONTEXT=${{ steps.buildx.outputs.name }} |