-
Notifications
You must be signed in to change notification settings - Fork 0
92 lines (83 loc) · 2.43 KB
/
ci.yml
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
name: ci
on:
push:
branches: [main]
pull_request:
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: prepare
uses: ./.github/actions/prepare
- name: Build
run: just build
clippy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: prepare
uses: ./.github/actions/prepare
- name: Run clippy
run: just clippy
rustfmt:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: prepare
uses: ./.github/actions/prepare
- name: Build autogenerated files
run: cargo check
- name: Check formatting
run: cargo fmt --check
unit-tests:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: prepare
uses: ./.github/actions/prepare
- name: Run unit-tests
run: just unit-test
miri:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: prepare
uses: ./.github/actions/prepare
- name: Run miri
run: just miri
system-tests:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: prepare
uses: ./.github/actions/prepare
- name: Build
run: just system-test
# This job allows to view the cache content as a job artifacte
# Github doesn't allow to view the cache directly
# cache-analysis:
# runs-on: ubuntu-latest
# steps:
# - uses: actions/checkout@v4
# - uses: actions/cache@v4
# id: cache-id
# with:
# path: ${{ runner.temp }}/ci-cache
# key: ${{ runner.os }}-${{ hashFiles('.github/workflows/setup.sh', 'Cargo.lock', 'system-tests/Cargo.lock', 'rust-toolchain', '.github/actions/prepare/action.yml')}}
# # Unfortunately the artifact doesn't allow colons ':' in filenames
# # Therefore, just replace them
# - name: Replace colon file names
# run: |
# cd ${{ runner.temp }}/ci-cache
# find . -name '*:*' -type f | while read -r file; do
# mv "$file" "$(echo $file | sed 's/:/-/g')"
# done
# - name: upload artifact
# uses: actions/upload-artifact@v4
# with:
# path: ${{ runner.temp }}/ci-cache
# include-hidden-files: true
# # Use this to access the github runner via ssh
# - name: Setup tmate session
# uses: mxschmitt/action-tmate@v3