name: build on: push: branches: - 'main' pull_request: paths: - 'go.*' - '**/*.go' - 'Taskfile.yml' - 'Dockerfile' - '.github/workflows/build.yml' permissions: contents: read jobs: govulncheck: uses: caarlos0/meta/.github/workflows/govulncheck.yml@main with: cache: true go-version: '>=1.19.1' semgrep: uses: caarlos0/meta/.github/workflows/semgrep.yml@main ruleguard: uses: caarlos0/meta/.github/workflows/ruleguard.yml@main with: cache: true go-version: '>=1.19.1' args: '-disable largeloopcopy' test: runs-on: ubuntu-latest env: DOCKER_CLI_EXPERIMENTAL: "enabled" steps: - uses: actions/checkout@93ea575cb5d8a053eaa0ac8fa3b40d7e05a33cc8 # v3 with: fetch-depth: 0 - uses: arduino/setup-task@ca745e18916de727f841ec824ac20a615f1cddea # v1 with: version: 3.x repo-token: ${{ secrets.GITHUB_TOKEN }} - uses: docker/setup-qemu-action@8b122486cedac8393e77aa9734c3528886e4a1a8 # v1 - uses: docker/setup-buildx-action@dc7b9719a96d48369863986a06765841d7ea23f6 # v1 - name: setup-snapcraft # FIXME: the mkdirs are a hack for https://github.com/goreleaser/goreleaser/issues/1715 run: | sudo apt-get update sudo apt-get -yq --no-install-suggests --no-install-recommends install snapcraft mkdir -p $HOME/.cache/snapcraft/download mkdir -p $HOME/.cache/snapcraft/stage-packages - uses: actions/setup-go@268d8c0ca0432bb2cf416faae41297df9d262d7f # v3 with: go-version: '>=1.19.1' cache: true - uses: sigstore/cosign-installer@v2.7.0 - uses: anchore/sbom-action/download-syft@v0.12.0 - name: setup-validate-krew-manifest run: go install sigs.k8s.io/krew/cmd/validate-krew-manifest@latest - name: setup-tparse run: go install github.com/mfridman/tparse@latest - name: setup run: | task setup task build - name: test run: ./scripts/test.sh - uses: codecov/codecov-action@d9f34f8cd5cb3b3eb79b3e4b5dae3a16df499a70 # v3 with: file: ./coverage.txt - run: ./goreleaser check - run: git diff