-
Notifications
You must be signed in to change notification settings - Fork 2
102 lines (87 loc) · 2.71 KB
/
forge.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
93
94
95
96
97
98
99
100
101
102
# foundry workflow
name: forge
on:
push:
paths:
- "**.sol"
- "**.toml"
pull_request:
types: [opened, reopened, synchronize, ready_for_review]
# On-demand
workflow_dispatch: {}
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
env:
COMMIT_SHA: ${{ github.event.pull_request.head.sha }}
PULL_NUMBER: ${{ github.event.pull_request.number }}
RUN_ID: ${{ github.run_id }}
FORCE_COLOR: 2
jobs:
workflow:
# User-definable name of this GitHub Actions job:
# If you are self-hosting, change the following `runs-on` value:
# <https://github.com/actions/runner-images/blob/releases/ubuntu22/20230710/README.md#available-images>
# <ubuntu-22.04:sha256:0bced47fffa3361afa981854fcabcd4577cd43cebbb808cea2b1f33a3dd7f508>
name: Foundry Pipeline
runs-on: ${{ matrix.os }}
permissions:
contents: read
# required for all workflows
security-events: write
# only required for workflows in private repositories
actions: read
strategy:
fail-fast: false
matrix:
os: ['ubuntu-22.04']
steps:
- uses: actions/checkout@v4
- name: Install diffutils
run: sudo apt-get install diffutils
- name: Install Foundry
uses: foundry-rs/foundry-toolchain@v1
with:
version: nightly
- name: Run Install
id: install
run: forge install
- name: Run forge config --fix
run: forge config --fix foundry.toml
- name: Check for changes
id: check_changes
run: |
git diff --exit-code foundry.toml || echo "changes" > changes_detected
- name: Fail if changes detected
if: steps.check_changes.outputs.changes_detected == 'changes'
run: |
echo "Changes detected in foundry.toml"
exit 1
- name: Comment on PR with changes
if: steps.check_changes.outputs.changes_detected == 'changes'
uses: peter-evans/create-or-update-comment@v1
with:
token: ${{ secrets.GITHUB_TOKEN }}
issue-number: ${{ github.event.pull_request.number }}
body: |
## Changes detected in `foundry.toml`
```diff
$(git diff foundry.toml)
```
# TODO:
# fix Justfile
#
# - uses: extractions/setup-just@v2
# - name: Run Forge build
# run: just build
# id: build
# - name: Run Tests
# id: test
# run: just test
- name: Run Slither
uses: crytic/[email protected]
id: slither
with:
fail-on: all
slither-args: --compile-force-framework foundry --exclude-dependencies --checklist
solc-version: "0.8.19"