This repository has been archived on 2024-07-08. You can view files and clone it, but cannot push or open issues or pull requests.
nix-config-tn/.github/workflows/build.yml
jahanson 7be726e744
Some checks failed
Build / nix-build (native-aarch64, varda) (push) Failing after 4s
Build / nix-build (ubuntu-x86_64, durincore) (push) Failing after 1m45s
Build / Nix Build Successful (push) Successful in 1s
Native nix
2024-05-21 13:19:54 -05:00

83 lines
No EOL
2.6 KiB
YAML

name: "Build"
on:
pull_request:
push:
jobs:
nix-build:
if: github.event.pull_request.draft == false
strategy:
fail-fast: false
matrix:
include:
- system: varda
os: native-aarch64
- system: durincore
os: ubuntu-x86_64
runs-on: ${{ matrix.os }}
container:
image: docker.io/library/ubuntu:latest
steps:
- name: Install sudo and node
if: contains(matrix.os, 'ubuntu')
# For compatibility with actions and debian
run: apt update && apt install -y nodejs npm sudo udev curl lvm2
- name: Create nix mount point
if: contains(matrix.os, 'ubuntu')
run: sudo mkdir /nix
- name: Maximize build space
if: contains(matrix.os, 'ubuntu')
uses: https://github.com/easimon/maximize-build-space@v10
with:
root-reserve-mb: 512
swap-size-mb: 1024
build-mount-path: "/nix"
remove-dotnet: true
remove-android: true
remove-haskell: true
remove-codeql: true
overprovision-lvm: true
- name: Checkout repository
uses: https://github.com/actions/checkout@v4
with:
fetch-depth: 0
- name: Install Nix
if: contains(matrix.os, 'ubuntu')
uses: https://github.com/cachix/install-nix-action@v26
with:
extra_nix_config: |
experimental-features = nix-command flakes
nix_path: nixpkgs=channel:nixos-unstable
# - uses: https://github.com/DeterminateSystems/magic-nix-cache-action@main
- uses: https://github.com/cachix/cachix-action@v14
if: ${{ !github.event.pull_request.head.repo.fork }}
with:
name: hsndev
# If you chose API tokens for write access OR if you have a private cache
authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}'
env:
USER: 'root'
- name: Garbage collect build dependencies
run: nix-collect-garbage
- name: Build new ${{ matrix.system }} system
shell: bash
run: |
set -o pipefail
nix build \
".#top.${{ matrix.system }}" \
--profile ./profile \
--fallback \
-v \
--log-format raw \
> >(tee stdout.log) 2> >(tee /tmp/nix-build-err.log >&2)
nix-build-success:
if: ${{ always() }}
needs:
- nix-build
name: Nix Build Successful
runs-on: docker
steps:
- if: ${{ contains(needs.*.result, 'failure') || contains(needs.*.result, 'cancelled') }}
name: Check matrix status
run: exit 1