Skip to content

ci: bump actions/cache from 3 to 5 (#43) #453

ci: bump actions/cache from 3 to 5 (#43)

ci: bump actions/cache from 3 to 5 (#43) #453

Workflow file for this run

name: CI
on:
push:
jobs:
test:
name: Test
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v6
with:
go-version: '1.25.x'
cache: true
- name: Download dependencies
run: go mod download
- name: Verify dependencies
run: go mod verify
- name: Run tests
run: make test
- name: Generate coverage report
run: go test -coverprofile=coverage.out ./...
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v3
with:
file: ./coverage.out
flags: unittests
name: codecov-umbrella
lint:
name: Lint
runs-on: ubuntu-latest
continue-on-error: true # golangci-lint doesn't support Go 1.25 yet
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v6
with:
go-version: '1.25.x'
cache: true
- name: Download dependencies
run: go mod download
- name: Tidy go.mod
run: go mod tidy
- name: Run golangci-lint
uses: golangci/golangci-lint-action@v9
with:
version: latest
args: --timeout=5m
continue-on-error: true # Ignore errors until golangci-lint supports Go 1.25
codegen:
name: OpenAPI Codegen Check
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v6
with:
go-version: '1.25.x'
cache: true
- name: Install oapi-codegen
run: go install github.com/oapi-codegen/oapi-codegen/v2/cmd/oapi-codegen@latest
- name: Check generated code is up-to-date
run: make generate-check
build:
name: Build
runs-on: ubuntu-latest
needs: [test, lint, codegen]
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v6
with:
go-version: '1.25.x'
cache: true
- name: Download dependencies
run: go mod download
- name: Build application
run: make build
- name: Upload build artifacts
uses: actions/upload-artifact@v4
with:
name: gogocoin-binary
path: bin/gogocoin
retention-days: 7
security:
name: Security Scan
runs-on: ubuntu-latest
permissions:
security-events: write
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v6
with:
go-version: '1.25.x'
cache: true
- name: Run Gosec Security Scanner
uses: securego/gosec@master
with:
args: '-no-fail -fmt sarif -out results.sarif ./...'
- name: Upload SARIF file
if: github.event_name == 'push' && github.ref == 'refs/heads/main'
uses: github/codeql-action/upload-sarif@v4
with:
sarif_file: results.sarif
docker:
name: Docker Build Test
runs-on: ubuntu-latest
needs: [test, lint]
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build Docker image (test only)
uses: docker/build-push-action@v7
with:
context: .
platforms: linux/amd64
push: false
tags: gogocoin:test
cache-from: type=gha
cache-to: type=gha,mode=max