mirror of
https://github.com/replicatedhq/troubleshoot.git
synced 2026-02-14 18:29:53 +00:00
Bumps [actions/download-artifact](https://github.com/actions/download-artifact) from 4 to 5. - [Release notes](https://github.com/actions/download-artifact/releases) - [Commits](https://github.com/actions/download-artifact/compare/v4...v5) --- updated-dependencies: - dependency-name: actions/download-artifact dependency-version: '5' dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
282 lines
7.5 KiB
YAML
282 lines
7.5 KiB
YAML
name: build-test-deploy
|
|
|
|
on:
|
|
pull_request:
|
|
types:
|
|
- opened
|
|
- reopened
|
|
- synchronize
|
|
- ready_for_review
|
|
branches:
|
|
- main
|
|
push:
|
|
branches:
|
|
- "main"
|
|
tags:
|
|
- "v*.*.*"
|
|
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
fail_if_pull_request_is_draft:
|
|
if: github.event.pull_request.draft == true
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Fails in order to indicate that pull request needs to be marked as ready to review and unit tests workflow needs to pass.
|
|
run: exit 1
|
|
|
|
tidy-check:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: actions/setup-go@v5
|
|
with:
|
|
go-version-file: 'go.mod'
|
|
- run: make tidy-diff
|
|
|
|
test-integration:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: actions/setup-go@v5
|
|
with:
|
|
go-version-file: 'go.mod'
|
|
- uses: replicatedhq/action-k3s@main
|
|
id: k3s
|
|
with:
|
|
version: v1.31.2-k3s1
|
|
# test-integration includes unit tests
|
|
- run: make test-integration
|
|
|
|
ensure-schemas-are-generated:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0
|
|
- uses: actions/setup-go@v5
|
|
with:
|
|
go-version-file: 'go.mod'
|
|
- run: |
|
|
make check-schemas
|
|
|
|
compile-preflight:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: actions/setup-go@v5
|
|
with:
|
|
go-version-file: 'go.mod'
|
|
- run: make generate preflight
|
|
- uses: actions/upload-artifact@v4
|
|
with:
|
|
name: preflight
|
|
path: bin/preflight
|
|
|
|
validate-preflight-e2e:
|
|
runs-on: ubuntu-latest
|
|
needs: compile-preflight
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: replicatedhq/action-k3s@main
|
|
id: k3s
|
|
with:
|
|
version: v1.31.2-k3s1
|
|
- name: Download preflight binary
|
|
uses: actions/download-artifact@v5
|
|
with:
|
|
name: preflight
|
|
path: bin/
|
|
- run: chmod +x bin/preflight
|
|
- run: make preflight-e2e-test
|
|
|
|
run-examples:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- run: make run-examples
|
|
|
|
compile-supportbundle:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: actions/setup-go@v5
|
|
with:
|
|
go-version-file: 'go.mod'
|
|
- run: make generate support-bundle
|
|
- uses: actions/upload-artifact@v4
|
|
with:
|
|
name: support-bundle
|
|
path: bin/support-bundle
|
|
|
|
validate-supportbundle-e2e:
|
|
runs-on: ubuntu-latest
|
|
needs: compile-supportbundle
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: replicatedhq/action-k3s@main
|
|
id: k3s
|
|
with:
|
|
version: v1.31.2-k3s1
|
|
- name: Download support bundle binary
|
|
uses: actions/download-artifact@v5
|
|
with:
|
|
name: support-bundle
|
|
path: bin/
|
|
- run: chmod +x bin/support-bundle
|
|
- run: make support-bundle-e2e-test
|
|
|
|
# Additional e2e tests for support bundle that run in Go, these create a Kind cluster
|
|
validate-supportbundle-e2e-go:
|
|
runs-on: ubuntu-latest
|
|
needs: compile-supportbundle
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- name: Download support bundle binary
|
|
uses: actions/download-artifact@v5
|
|
with:
|
|
name: support-bundle
|
|
path: bin/
|
|
- run: chmod +x bin/support-bundle
|
|
- name: Download preflight binary
|
|
uses: actions/download-artifact@v5
|
|
with:
|
|
name: preflight
|
|
path: bin/
|
|
- run: chmod +x bin/preflight
|
|
- run: make support-bundle-e2e-go-test
|
|
|
|
compile-collect:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: actions/setup-go@v5
|
|
with:
|
|
go-version-file: 'go.mod'
|
|
- run: make generate collect
|
|
- uses: actions/upload-artifact@v4
|
|
with:
|
|
name: collect
|
|
path: bin/collect
|
|
|
|
goreleaser-test:
|
|
runs-on: ubuntu-latest
|
|
if: startsWith(github.ref, 'refs/tags/v') != true
|
|
strategy:
|
|
matrix:
|
|
goarch: [amd64, arm64]
|
|
goos: [darwin, linux]
|
|
include:
|
|
- goarch: arm
|
|
goos: linux
|
|
- goarch: riscv64
|
|
goos: linux
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0
|
|
|
|
- uses: actions/setup-go@v5
|
|
with:
|
|
go-version-file: 'go.mod'
|
|
|
|
- name: Run GoReleaser
|
|
uses: goreleaser/goreleaser-action@v6
|
|
with:
|
|
version: "v0.183.0"
|
|
args: build --rm-dist --snapshot --config deploy/.goreleaser.yaml --single-target
|
|
env:
|
|
GOARCH: ${{ matrix.goarch }}
|
|
GOOS: ${{ matrix.goos }}
|
|
|
|
goreleaser:
|
|
runs-on: ubuntu-latest
|
|
needs:
|
|
- validate-preflight-e2e
|
|
- validate-supportbundle-e2e
|
|
if: startsWith(github.ref, 'refs/tags/v')
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0
|
|
|
|
- uses: azure/docker-login@v2
|
|
with:
|
|
username: ${{ secrets.DOCKERHUB_USER }}
|
|
password: ${{ secrets.DOCKERHUB_PASSWORD }}
|
|
|
|
- uses: actions/setup-go@v5
|
|
with:
|
|
go-version-file: 'go.mod'
|
|
|
|
- uses: sigstore/cosign-installer@v3.9.2
|
|
|
|
- name: Get Cosign Key
|
|
run: |
|
|
echo $COSIGN_KEY | base64 -d > ./cosign.key
|
|
env:
|
|
COSIGN_KEY: ${{secrets.COSIGN_KEY}}
|
|
|
|
- name: Generate SBOM
|
|
run: |
|
|
make sbom
|
|
env:
|
|
COSIGN_PASSWORD: ${{ secrets.COSIGN_PASSWORD }}
|
|
COSIGN_KEY: ${{ secrets.COSIGN_KEY }}
|
|
|
|
- name: Run GoReleaser
|
|
uses: goreleaser/goreleaser-action@v6
|
|
with:
|
|
version: "v1.x" # Binary version to install
|
|
args: release --clean --config deploy/.goreleaser.yaml
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Update new preflight version in krew-index
|
|
uses: rajatjindal/krew-release-bot@v0.0.47
|
|
with:
|
|
krew_template_file: deploy/krew/preflight.yaml
|
|
- name: Update new support-bundle version in krew-index
|
|
uses: rajatjindal/krew-release-bot@v0.0.47
|
|
with:
|
|
krew_template_file: deploy/krew/support-bundle.yaml
|
|
|
|
|
|
# summary jobs, these jobs will only run if all the other jobs have succeeded
|
|
validate-pr-tests:
|
|
runs-on: ubuntu-latest
|
|
needs:
|
|
- tidy-check
|
|
- test-integration
|
|
- run-examples
|
|
- compile-collect
|
|
- validate-preflight-e2e
|
|
- validate-supportbundle-e2e
|
|
- validate-supportbundle-e2e-go
|
|
- ensure-schemas-are-generated
|
|
steps:
|
|
- run: echo "All PR tests passed"
|
|
|
|
|
|
# this job will validate that the validation did not fail and that all pr-tests succeed
|
|
# it is used for the github branch protection rule
|
|
validate-success:
|
|
runs-on: ubuntu-latest
|
|
needs:
|
|
- validate-pr-tests
|
|
if: always()
|
|
steps:
|
|
# https://docs.github.com/en/actions/learn-github-actions/contexts#needs-context
|
|
# if the validate-pr-tests job was not successful, this job will fail
|
|
- name: fail if validate-pr-tests job was not successful
|
|
if: needs.validate-pr-tests.result != 'success'
|
|
run: exit 1
|
|
# if the validate-pr-tests job was successful, this job will succeed
|
|
- name: succeed if validate-pr-tests job succeeded
|
|
if: needs.validate-pr-tests.result == 'success'
|
|
run: echo "Validation succeeded"
|