54 lines
1.5 KiB
YAML
54 lines
1.5 KiB
YAML
|
name: CI
|
||
|
|
||
|
on:
|
||
|
push:
|
||
|
pull_request:
|
||
|
|
||
|
env:
|
||
|
ATTIC_AUTH_TOKEN: ${{ secrets.ATTIC_AUTH_TOKEN }}
|
||
|
|
||
|
jobs:
|
||
|
build:
|
||
|
container: nixpkgs/nix-flakes:nixos-24.05
|
||
|
steps:
|
||
|
- name: Initialize CI
|
||
|
uses: https://git.qo.is/qo.is/actions-nix-init@main
|
||
|
with:
|
||
|
token: ${{ secrets.CI_TOKEN }}
|
||
|
lfs: false
|
||
|
|
||
|
- name: Add submodules to nix store to circumvent another nix bug
|
||
|
run: |
|
||
|
git clone https://git.qo.is/qo.is/infrastructure-private.git /tmp/private
|
||
|
cd /tmp/private
|
||
|
nix flake prefetch
|
||
|
|
||
|
- name: Use attic cache
|
||
|
run: nix run .#cache use
|
||
|
|
||
|
- name: Build
|
||
|
run: |
|
||
|
nix run .#cache watch &
|
||
|
nix build --max-jobs 12 --cores 12
|
||
|
kill %1
|
||
|
nix run .#cache push
|
||
|
|
||
|
- name: Run Checks
|
||
|
run: |
|
||
|
nix run .#cache watch &
|
||
|
nix flake check
|
||
|
kill %1
|
||
|
|
||
|
- name: Deploy Docs
|
||
|
if: success() && github.ref == 'refs/heads/main'
|
||
|
run: |
|
||
|
nix run .#cache watch &
|
||
|
mkdir ~/.ssh/
|
||
|
echo -e "Host lindberg-webapps.backplane.net.qo.is\n StrictHostKeyChecking no" >> ~/.ssh/config
|
||
|
(umask 0077 && printf "%s\n" "${{ secrets.SSH_DEPLOY_KEY }}" > ~/.ssh/id_ed25519)
|
||
|
# Remote build might be neccessary due to non-wheel nix users signing restrictions.
|
||
|
# However, the build should come from the cache anyway.
|
||
|
nix develop --command deploy --skip-checks --remote-build .#lindberg-webapps.\"docs-ops.qo.is\"
|
||
|
kill %1
|
||
|
|