nixos-config/.github/workflows/check-deploy.yml
SebastianStork 71132b3c94
Some checks are pending
Check & Deploy / generate-matrix (push) Waiting to run
Check & Deploy / build-check (push) Blocked by required conditions
Check & Deploy / flake-check (push) Blocked by required conditions
Check & Deploy / deploy (push) Blocked by required conditions
workflows/check-deploy: Build checks individually for cachix caching
2026-02-18 17:29:57 +01:00

57 lines
1.8 KiB
YAML

name: "Check & Deploy"
on:
workflow_dispatch:
push:
branches: [main]
jobs:
generate-matrix:
runs-on: ubuntu-latest
outputs:
checks: ${{ steps.checks.outputs.checks }}
steps:
- uses: actions/checkout@v5
- uses: cachix/install-nix-action@v31
with:
extra_nix_config: experimental-features = nix-command flakes pipe-operators
- id: checks
run: |
checks=$(nix flake show --json | jq -c '.checks."x86_64-linux" | keys')
printf "checks=%s" "$checks" >> "$GITHUB_OUTPUT"
build-check:
needs: generate-matrix
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
check: ${{ fromJson(needs.generate-matrix.outputs.checks) }}
steps:
- uses: actions/checkout@v5
- uses: cachix/install-nix-action@v31
with:
extra_nix_config: experimental-features = nix-command flakes pipe-operators
- uses: cachix/cachix-action@v15
with:
name: sebastian-stork
authToken: "${{ secrets.CACHIX_AUTH_TOKEN }}"
- run: nix build .#checks.x86_64-linux.${{ matrix.check }} --print-build-logs
flake-check:
needs: build-check
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v5
- uses: cachix/install-nix-action@v31
with:
extra_nix_config: experimental-features = nix-command flakes pipe-operators
- uses: cachix/cachix-action@v15
with:
name: sebastian-stork
authToken: "${{ secrets.CACHIX_AUTH_TOKEN }}"
- run: nix flake check --keep-going --print-build-logs
deploy:
needs: flake-check
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- uses: actions/checkout@v5
- run: git push origin HEAD:deploy --force