nixfiles/.gitea/workflows/ci.yaml

42 lines
1.4 KiB
YAML
Raw Normal View History

2023-11-16 22:00:49 +00:00
name: CI
on:
push:
branches: [master]
jobs:
check:
2023-11-17 15:39:31 +00:00
name: Check, build and cache Nix flake
2023-11-16 22:00:49 +00:00
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
2024-06-30 13:10:23 +01:00
- uses: cachix/install-nix-action@v27
with:
# Gitea will supply a token in GITHUB_TOKEN, which this action will
# try to pass to Nix when downloading from GitHub
github_access_token: ${{ secrets.GH_PULL_TOKEN }}
extra_nix_config: |
# Make sure we're using sandbox
sandbox-fallback = false
2024-06-30 13:10:23 +01:00
# Big C++ projects fill up memory...
cores = 6
2023-11-17 22:57:44 +00:00
2023-11-17 15:05:19 +00:00
extra-substituters = https://nix-cache.nul.ie/main
2023-11-17 21:45:29 +00:00
extra-trusted-public-keys = main:mMChkG8LwXrFirVfudqjSHasK1jV31OVElYD3eImYl8=
2023-11-17 15:05:19 +00:00
- name: Set up attic
run: |
nix run .#nixpkgs.mine.x86_64-linux.attic-client -- \
login --set-default colony https://nix-cache.nul.ie "${{ secrets.NIX_CACHE_TOKEN }}"
2023-11-16 22:00:49 +00:00
- name: Check flake
run: nix flake check
- name: Build the world
2023-11-17 15:39:31 +00:00
id: build
run: |
path=$(nix build --no-link .#ci.x86_64-linux --json | jq -r .[0].outputs.out)
echo "path=$path" >> "$GITHUB_OUTPUT"
2023-11-17 15:05:19 +00:00
- name: Push to cache
run: |
nix run .#nixpkgs.mine.x86_64-linux.attic-client -- \
2023-11-17 15:39:31 +00:00
push main ${{ steps.build.outputs.path }}