-
-
Notifications
You must be signed in to change notification settings - Fork 0
141 lines (116 loc) · 3.57 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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
name: Continuous Integration
on:
push:
branches: [master, feature/*]
# pull_request:
# branches: [master]
workflow_call:
workflow_dispatch:
jobs:
format:
name: Check Format
runs-on: ubuntu-latest
continue-on-error: true
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Checkout 3rd-party
uses: ./.github/actions/checkout
- name: Install toolchain
uses: ./.github/actions/rust-toolchain
with:
components: rustfmt
- name: Check format
run: cargo fmt --all -- --check
audit:
name: Cargo Audit
runs-on: ubuntu-latest
continue-on-error: true
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Audit packages
uses: bitwizeshift/rust-actions/cargo-audit@master
check:
name: Check Manifest
runs-on: ubuntu-latest
continue-on-error: true
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Prepare runner
uses: ./.github/actions/prepare-runner
- name: Install toolchain
uses: ./.github/actions/rust-toolchain
- name: Check manifest
run: cargo check --verbose --workspace
licenses:
name: Cargo licenses
runs-on: ubuntu-latest
continue-on-error: true
env:
OUTPUT_FILE: licenses.html
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Prepare runner
uses: ./.github/actions/prepare-runner
- name: Check cargo-deny
uses: bitwizeshift/rust-actions/cargo-deny@master
- name: Generate license manifest
id: license-manifest
uses: ./.github/actions/cargo-about
with:
output-file: ${{env.OUTPUT_FILE}}
- name: Upload License Manifest Artifact
uses: actions/upload-artifact@v4
if: steps.license-manifest.outcome == 'success'
continue-on-error: true
with:
name: licenses
path: ${{env.OUTPUT_FILE}}
clippy:
name: Static Analysis
runs-on: ubuntu-latest
continue-on-error: true
permissions:
contents: read
security-events: write
actions: read
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Prepare runner
uses: ./.github/actions/prepare-runner
- name: Checkout 3rd-party
uses: ./.github/actions/checkout
- name: Install toolchain
uses: ./.github/actions/rust-toolchain
with:
components: clippy
- name: Install clippy-sarif
uses: ./.github/actions/cargo-install
with:
target: clippy-sarif
- name: Install sarif-fmt
uses: ./.github/actions/cargo-install
with:
target: sarif-fmt
- name: Check clippy
continue-on-error: true
run: |
cargo clippy \
--no-deps \
--message-format=json \
-- --deny clippy::all \
| clippy-sarif \
| tee rust-clippy-results.sarif \
| sarif-fmt
- name: Upload analysis results to GitHub
uses: github/codeql-action/upload-sarif@v3
with:
sarif_file: rust-clippy-results.sarif
wait-for-processing: true
build:
name: Build and Test
uses: ./.github/workflows/build-and-test.yaml