-
Notifications
You must be signed in to change notification settings - Fork 2
83 lines (67 loc) · 2.51 KB
/
Copy pathci-format-test-lint.yml
File metadata and controls
83 lines (67 loc) · 2.51 KB
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
name: ci-format-test-lint
on:
push:
branches: ["main"]
pull_request:
branches: ["main"]
jobs:
build-and-test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
with:
submodules: "recursive"
- uses: bazel-contrib/setup-bazel@0.18.0
with:
bazelisk-cache: true
disk-cache: ${{ github.workflow }}
repository-cache: true
- name: Build
run: bazel build //...
- name: Test
run: bazel test //test/...
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
with:
submodules: "recursive"
- uses: bazel-contrib/setup-bazel@0.18.0
with:
bazelisk-cache: true
disk-cache: ${{ github.workflow }}
repository-cache: true
- name: Build all targets
run: bazel build //...
- name: Build compilation database
run: bazel run @hedron_compile_commands//:refresh_all
- name: Debug DB
run: |
echo "Current Dir: $(pwd)"
ls -lh compile_commands.json
# Check if the file with errors is actually in the DB
grep "client_api.cpp" compile_commands.json | head -n 1 || echo "FILE NOT IN DB"
- uses: cpp-linter/cpp-linter-action@v2
id: linter
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
style: "file" # Use .clang-format config file.
tidy-checks: "" # Use .clang-tidy config file.
database: "compile_commands.json"
version: "21"
extra-args: "--system-headers -fdiagnostics-absolute-paths"
- name: Fail fast?!
if: steps.linter.outputs.checks-failed > 0
run: exit 1
- name: ☢️ NUCLEAR DEBUG - Manual Clang-Tidy Run
run: |
echo "=== 1. Checking Database Entry ==="
# Check how the file is referenced in the DB (Absolute vs Relative paths)
grep "openfeature/evaluation_context.h" compile_commands.json | head -n 1
echo "=== 2. Running Clang-Tidy Manually ==="
# We manually invoke clang-tidy on a file we KNOW has errors.
# We explicitly point to the config and the build folder.
clang-tidy -p . openfeature/evaluation_context.h --config-file=.clang-tidy || echo "Manual Run Failed as Expected"
echo "=== 3. Running Clang-Tidy 16 Manually ==="
/usr/bin/clang-tidy-20 -p . openfeature/evaluation_context.h --config-file=.clang-tidy || echo "Manual Run Failed as Expected"