Skip to content

build(deps): bump actions/upload-pages-artifact from 3 to 4 #22

build(deps): bump actions/upload-pages-artifact from 3 to 4

build(deps): bump actions/upload-pages-artifact from 3 to 4 #22

Workflow file for this run

name: CI
on:
push:
branches: [main]
pull_request:
branches: [main]
permissions:
contents: read
env:
go-version: "1.26.0"
lint-version: "v2.9.0"
jobs:
test:
name: Test (${{ matrix.os }})
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest, macos-latest]
steps:
- uses: actions/checkout@v6
- uses: actions/setup-go@v6
with:
go-version: ${{ env.go-version }}
cache: true
- name: Verify module consistency
run: go mod verify
- name: Build
run: go build ./...
- name: Test
run: go test -v -race -coverprofile=coverage.out -covermode=atomic ./...
- name: Upload coverage to Codecov
# Only upload from one OS to avoid double-counting.
if: matrix.os == 'ubuntu-latest'
uses: codecov/codecov-action@v5
with:
files: ./coverage.out
flags: unittests
name: git-profile-coverage
fail_ci_if_error: false # don't fail CI if Codecov is unavailable
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
lint:
name: Lint
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
- uses: actions/setup-go@v6
with:
go-version: ${{ env.go-version }}
cache: true
- name: golangci-lint
uses: golangci/golangci-lint-action@v9
with:
version: ${{ env.lint-version }}
args: --timeout=5m
vuln:
name: Vulnerability scan
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
- uses: actions/setup-go@v6
with:
go-version: ${{ env.go-version }}
cache: true
- name: Install govulncheck
run: go install golang.org/x/vuln/cmd/govulncheck@latest
- name: Run govulncheck
run: govulncheck ./...
build-snapshot:
name: Build snapshot
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
with:
fetch-depth: 0
- uses: actions/setup-go@v6
with:
go-version: ${{ env.go-version }}
cache: true
- uses: goreleaser/goreleaser-action@v7
with:
distribution: goreleaser
version: "~> v2"
args: release --snapshot --clean