mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-01 19:47:37 +03:00
* Remove workaround for missing `context.WithoutCancel` in Go 1.20 * Upgrade to Go 1.22 * Upgrade GitHub Actions * Upgrade Node to v20
230 lines
6.1 KiB
YAML
230 lines
6.1 KiB
YAML
name: "Pipeline: Test, Lint, Build"
|
|
on:
|
|
push:
|
|
branches:
|
|
- master
|
|
tags:
|
|
- "v*"
|
|
pull_request:
|
|
branches:
|
|
- master
|
|
jobs:
|
|
go-lint:
|
|
name: Lint Go code
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Update ubuntu repo
|
|
run: sudo apt-get update
|
|
|
|
- name: Install taglib
|
|
run: sudo apt-get install libtag1-dev
|
|
|
|
- name: Set up Go
|
|
uses: actions/setup-go@v5
|
|
with:
|
|
go-version: 1.22.x
|
|
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: golangci-lint
|
|
uses: golangci/golangci-lint-action@v4
|
|
with:
|
|
version: latest
|
|
github-token: ${{ secrets.GITHUB_TOKEN }}
|
|
args: --timeout 2m
|
|
|
|
- name: Install goimports
|
|
run: go install golang.org/x/tools/cmd/goimports
|
|
|
|
- run: goimports -w `find . -name '*.go' | grep -v '_gen.go$'`
|
|
- run: go mod tidy
|
|
- name: Verify no changes from goimports and go mod tidy
|
|
run: |
|
|
git status --porcelain
|
|
if [ -n "$(git status --porcelain)" ]; then
|
|
echo 'To fix this check, run "make format" and commit the changes'
|
|
exit 1
|
|
fi
|
|
|
|
go:
|
|
name: Test with Go ${{ matrix.go_version }}
|
|
runs-on: ubuntu-latest
|
|
strategy:
|
|
matrix:
|
|
go_version: [1.22.x, 1.21.x]
|
|
steps:
|
|
- name: Update ubuntu repo
|
|
run: sudo apt-get update
|
|
|
|
- name: Install taglib
|
|
run: sudo apt-get install libtag1-dev ffmpeg
|
|
|
|
- name: Check out code into the Go module directory
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Set up Go ${{ matrix.go_version }}
|
|
uses: actions/setup-go@v5
|
|
with:
|
|
go-version: ${{ matrix.go_version }}
|
|
cache: true
|
|
|
|
- name: Download dependencies
|
|
if: steps.cache-go.outputs.cache-hit != 'true'
|
|
continue-on-error: ${{contains(matrix.go_version, 'beta') || contains(matrix.go_version, 'rc')}}
|
|
run: go mod download
|
|
|
|
- name: Test
|
|
continue-on-error: ${{contains(matrix.go_version, 'beta') || contains(matrix.go_version, 'rc')}}
|
|
run: go test -shuffle=on -race -cover ./... -v
|
|
|
|
js:
|
|
name: Build JS bundle
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
NODE_OPTIONS: "--max_old_space_size=4096"
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
- uses: actions/setup-node@v4
|
|
with:
|
|
node-version: 20
|
|
cache: "npm"
|
|
cache-dependency-path: "**/package-lock.json"
|
|
|
|
- name: npm install dependencies
|
|
run: |
|
|
cd ui
|
|
npm ci
|
|
|
|
- name: npm lint
|
|
run: |
|
|
cd ui
|
|
npm run check-formatting && npm run lint
|
|
|
|
- name: npm test
|
|
run: |
|
|
cd ui
|
|
npm test
|
|
|
|
- name: npm build
|
|
run: |
|
|
cd ui
|
|
npm run build
|
|
|
|
- uses: actions/upload-artifact@v4
|
|
with:
|
|
name: js-bundle
|
|
path: ui/build
|
|
retention-days: 7
|
|
|
|
binaries:
|
|
name: Build binaries
|
|
needs: [js, go, go-lint]
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Checkout Code
|
|
uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0
|
|
|
|
- uses: actions/download-artifact@v4
|
|
with:
|
|
name: js-bundle
|
|
path: ui/build
|
|
|
|
- name: Config /github/workspace folder as trusted
|
|
uses: docker://deluan/ci-goreleaser:1.22.0-1
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
with:
|
|
args: /bin/bash -c "git config --global --add safe.directory /github/workspace; git describe --dirty --always --tags"
|
|
|
|
- name: Run GoReleaser - SNAPSHOT
|
|
if: startsWith(github.ref, 'refs/tags/') != true
|
|
uses: docker://deluan/ci-goreleaser:1.22.0-1
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
with:
|
|
args: goreleaser release --clean --skip=publish --snapshot
|
|
|
|
- name: Run GoReleaser - RELEASE
|
|
if: startsWith(github.ref, 'refs/tags/')
|
|
uses: docker://deluan/ci-goreleaser:1.22.0-1
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
with:
|
|
args: goreleaser release --clean
|
|
|
|
- uses: actions/upload-artifact@v4
|
|
with:
|
|
name: binaries
|
|
path: |
|
|
dist
|
|
!dist/*.tar.gz
|
|
!dist/*.zip
|
|
retention-days: 7
|
|
|
|
docker:
|
|
name: Build and publish Docker images
|
|
needs: [binaries]
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
DOCKER_IMAGE: ${{secrets.DOCKER_IMAGE}}
|
|
steps:
|
|
- name: Set up QEMU
|
|
id: qemu
|
|
uses: docker/setup-qemu-action@v3
|
|
if: env.DOCKER_IMAGE != ''
|
|
|
|
- name: Set up Docker Buildx
|
|
id: buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
if: env.DOCKER_IMAGE != ''
|
|
|
|
- uses: actions/checkout@v4
|
|
if: env.DOCKER_IMAGE != ''
|
|
|
|
- uses: actions/download-artifact@v4
|
|
if: env.DOCKER_IMAGE != ''
|
|
with:
|
|
name: binaries
|
|
path: dist
|
|
|
|
- name: Login to Docker Hub
|
|
if: env.DOCKER_IMAGE != ''
|
|
uses: docker/login-action@v3
|
|
with:
|
|
username: ${{ secrets.DOCKER_USERNAME }}
|
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
|
|
|
- name: Login to GitHub Container Registry
|
|
if: env.DOCKER_IMAGE != ''
|
|
uses: docker/login-action@v3
|
|
with:
|
|
registry: ghcr.io
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Extract metadata for Docker
|
|
if: env.DOCKER_IMAGE != ''
|
|
id: meta
|
|
uses: docker/metadata-action@v5
|
|
with:
|
|
labels: |
|
|
maintainer=deluan
|
|
images: |
|
|
name=${{secrets.DOCKER_IMAGE}}
|
|
name=ghcr.io/${{ github.repository }}
|
|
tags: |
|
|
type=ref,event=pr
|
|
type=semver,pattern={{version}}
|
|
type=raw,value=develop,enable={{is_default_branch}}
|
|
|
|
- name: Build and Push
|
|
if: env.DOCKER_IMAGE != ''
|
|
uses: docker/build-push-action@v5
|
|
with:
|
|
context: .
|
|
file: .github/workflows/pipeline.dockerfile
|
|
platforms: linux/amd64,linux/386,linux/arm/v6,linux/arm/v7,linux/arm64
|
|
push: true
|
|
tags: ${{ steps.meta.outputs.tags }}
|