Compare commits

...

3 Commits

Author SHA1 Message Date
Ari Gerus 1f38b8529c forgejo actions: copy gh improvements, maybe?
CI / get-hosts (push) Successful in 1m34s Details
CI / aarch64-linux (push) Successful in 33s Details
CI / x86_64-linux (push) Successful in 1m38s Details
2024-03-19 13:55:38 +01:00
Ari Gerus 7425859788 gh actions: formatting 2024-03-19 13:49:53 +01:00
Ari Gerus fdff060112 gh actions: get hosts just once, and group them per-arch 2024-03-19 13:45:09 +01:00
2 changed files with 41 additions and 74 deletions

View File

@ -1,63 +1,52 @@
name: CI
on:
pull_request:
push:
branches: [main]
jobs:
get-x86_64-hosts:
get-hosts:
runs-on: self-hosted-x86_64-linux
outputs:
hosts: ${{ steps.output-hosts.outputs.hosts }}
matrix: ${{ steps.hosts_out.outputs.matrix }}
steps:
- uses: actions/checkout@v3
- name: output-hosts
- name: repository checkout
uses: actions/checkout@v4
- id: hosts_out
name: set hosts var
run: |
HOSTS_JSON="$(nix eval -I nixpkgs=$(nix flake metadata nixpkgs --json | jq -r .path) --raw --impure --expr '
with import <nixpkgs> { };
builtins.toJSON (lib.mapAttrsToList (n: v: n)
(lib.attrsets.filterAttrs (n: v: v.pkgs.system == pkgs.system)
(builtins.getFlake(builtins.toString ./.)).outputs.nixosConfigurations))'
)"
echo "::set-output name=hosts::${HOSTS_JSON}"
{
echo -n "matrix="
nix eval --raw --impure --expr '
let
f = configs: builtins.groupBy (n: configs.${n}.pkgs.system) (builtins.attrNames configs);
in
builtins.toJSON (f (builtins.getFlake(builtins.toString ./.)).outputs.nixosConfigurations)'
echo ""
} >> "$GITHUB_OUTPUT"
get-aarch64-hosts:
runs-on: self-hosted-aarch64-linux
outputs:
hosts: ${{ steps.output-hosts.outputs.hosts }}
steps:
- uses: actions/checkout@v3
- name: output-hosts
run: |
HOSTS_JSON="$(nix eval -I nixpkgs=$(nix flake metadata nixpkgs --json | jq -r .path) --raw --impure --expr '
with import <nixpkgs> { };
builtins.toJSON (lib.mapAttrsToList (n: v: n)
(lib.attrsets.filterAttrs (n: v: v.pkgs.system == pkgs.system)
(builtins.getFlake(builtins.toString ./.)).outputs.nixosConfigurations))'
)"
echo "::set-output name=hosts::${HOSTS_JSON}"
build-nixos-x86_64-linux:
x86_64-linux:
runs-on: self-hosted-x86_64-linux
needs: get-x86_64-hosts
needs: [get-hosts]
strategy:
fail-fast: false
matrix:
host: ${{fromJSON(needs.get-x86_64-hosts.outputs.hosts)}}
host: ${{ fromJson(needs.get-hosts.outputs.matrix).x86_64-linux }}
steps:
- uses: actions/checkout@v3
- name: repository checkout
uses: actions/checkout@v4
- name: build host configuration ${{ matrix.host }}
run: |
nixos-rebuild build --verbose --flake ".#${{ matrix.host }}"
run: nixos-rebuild build --verbose --flake ".#${{ matrix.host }}"
build-nixos-aarch64-linux:
aarch64-linux:
runs-on: self-hosted-aarch64-linux
needs: get-aarch64-hosts
needs: [get-hosts]
strategy:
fail-fast: false
matrix:
host: ${{fromJSON(needs.get-aarch64-hosts.outputs.hosts)}}
host: ${{ fromJson(needs.get-hosts.outputs.matrix).aarch64-linux }}
steps:
- uses: actions/checkout@v3
- name: repository checkout
uses: actions/checkout@v4
- name: build host configuration ${{ matrix.host }}
run: |
nixos-rebuild build --verbose --flake ".#${{ matrix.host }}"
run: nixos-rebuild build --verbose --flake ".#${{ matrix.host }}"

View File

@ -5,7 +5,7 @@ on:
branches: [main]
jobs:
get-x86_64-hosts:
get-hosts:
runs-on: self-hosted-x86_64-linux
outputs:
matrix: ${{ steps.hosts_out.outputs.matrix }}
@ -17,58 +17,36 @@ jobs:
run: |
{
echo -n "matrix="
nix eval -I nixpkgs=$(nix flake metadata nixpkgs --json | jq -r .path) --raw --impure --expr '
with import <nixpkgs> { };
builtins.toJSON (lib.mapAttrsToList (n: v: n)
(lib.attrsets.filterAttrs (n: v: v.pkgs.system == pkgs.system)
(builtins.getFlake(builtins.toString ./.)).outputs.nixosConfigurations))'
nix eval --raw --impure --expr '
let
f = configs: builtins.groupBy (n: configs.${n}.pkgs.system) (builtins.attrNames configs);
in
builtins.toJSON (f (builtins.getFlake(builtins.toString ./.)).outputs.nixosConfigurations)'
echo ""
} >> "$GITHUB_OUTPUT"
get-aarch64-hosts:
runs-on: self-hosted-aarch64-linux
outputs:
matrix: ${{ steps.hosts_out.outputs.matrix }}
steps:
- name: repository checkout
uses: actions/checkout@v4
- id: hosts_out
name: set hosts var
run: |
{
echo -n "matrix="
nix eval -I nixpkgs=$(nix flake metadata nixpkgs --json | jq -r .path) --raw --impure --expr '
with import <nixpkgs> { };
builtins.toJSON (lib.mapAttrsToList (n: v: n)
(lib.attrsets.filterAttrs (n: v: v.pkgs.system == pkgs.system)
(builtins.getFlake(builtins.toString ./.)).outputs.nixosConfigurations))'
echo ""
} >> "$GITHUB_OUTPUT"
build-nixos-x86_64-linux:
x86_64-linux:
runs-on: self-hosted-x86_64-linux
needs: [get-x86_64-hosts]
needs: [get-hosts]
strategy:
fail-fast: false
matrix:
host: ${{ fromJson(needs.get-x86_64-hosts.outputs.matrix) }}
host: ${{ fromJson(needs.get-hosts.outputs.matrix).x86_64-linux }}
steps:
- name: repository checkout
uses: actions/checkout@v4
- name: build host configuration ${{ matrix.host }}
run: nixos-rebuild build --verbose --flake ".#${{ matrix.host }}"
build-nixos-aarch64-linux:
aarch64-linux:
runs-on: self-hosted-aarch64-linux
needs: [get-aarch64-hosts]
needs: [get-hosts]
strategy:
fail-fast: false
matrix:
host: ${{ fromJson(needs.get-aarch64-hosts.outputs.matrix) }}
host: ${{ fromJson(needs.get-hosts.outputs.matrix).aarch64-linux }}
steps:
- name: repository checkout
uses: actions/checkout@v4
- name: build host configuration ${{ matrix.host }}
run: nixos-rebuild build --verbose --flake ".#${{ matrix.host }}"