-
Notifications
You must be signed in to change notification settings - Fork 43
98 lines (93 loc) · 3.07 KB
/
ci.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
name: CI
on:
push:
branches:
- master
pull_request:
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: cachix/install-nix-action@v16
with:
extra_nix_config: |
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
experimental-features = nix-command flakes recursive-nix
- uses: cachix/cachix-action@v10
with:
name: bernardo
signingKey: ${{ secrets.CACHIX_SIGNING_KEY }}
- name: lint
run: cachix watch-exec bernardo -- nix develop -c make lint
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: cachix/install-nix-action@v16
with:
extra_nix_config: |
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
experimental-features = nix-command flakes recursive-nix
- uses: cachix/cachix-action@v10
with:
name: bernardo
signingKey: ${{ secrets.CACHIX_SIGNING_KEY }}
- name: test
run: cachix watch-exec bernardo -- nix develop -c make test
get-pkgs:
runs-on: ubuntu-latest
outputs:
pkgs: ${{ steps.get-pkgs.outputs.pkgs }}
steps:
- uses: actions/checkout@v2
- uses: cachix/install-nix-action@v16
with:
extra_nix_config: |
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
experimental-features = nix-command flakes recursive-nix
- id: get-pkgs
run: echo "::set-output name=pkgs::$(nix flake show --json | jq -c '.packages."x86_64-linux" | keys')"
build:
name: build-${{ matrix.pkg }}
runs-on: ubuntu-latest
needs: get-pkgs
strategy:
fail-fast: false
matrix:
pkg: ${{ fromJson(needs.get-pkgs.outputs.pkgs) }}
steps:
- uses: actions/checkout@v2
- uses: cachix/install-nix-action@v16
with:
extra_nix_config: |
access-tokens = github.com=${{ secrets.GITHUB_TOKEN }}
experimental-features = nix-command flakes recursive-nix
- uses: cachix/cachix-action@v10
with:
name: bernardo
signingKey: ${{ secrets.CACHIX_SIGNING_KEY }}
- name: nix build
run: |
cachix watch-exec bernardo -- \
nix build -L .\#packages.x86_64-linux.${{ matrix.pkg }}
check:
runs-on: ubuntu-latest
needs: [ build ]
if: always()
steps:
- name: check
run: |
status_uri="https://api.github.com/repos/${{ github.repository }}/actions/runs/${{ github.run_id }}/jobs"
user_str="admin:${{ secrets.PAT }}"
run="$(curl -X GET -s -u "${user_str}" "${status_uri}")"
jobs="$(jq '.jobs[]' <<< "${run}")"
statuses="$(jq '{job: .name, status: .conclusion}' <<< "${jobs}")"
builds="$(jq 'select(.job | contains("build"))' <<< "${statuses}")"
failed="$(jq 'select(.status | contains("success") | not)' <<< "${builds}")"
if [ -z "${failed}" ]; then
echo "OK"
else
echo "FAIL"
exit 1
fi