-
Notifications
You must be signed in to change notification settings - Fork 1.1k
107 lines (89 loc) · 3.26 KB
/
lint-swagger.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
103
104
105
106
107
# yamllint disable rule:line-length rule:truthy
---
name: "Lint swagger schema"
on:
pull_request:
paths:
- 'swagger.yml'
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: ${{ github.event_name == 'pull_request' }}
jobs:
redocly_validator:
runs-on: ubuntu-latest
name: Validate the swagger with redocly cli
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 20
- name: Validate OpenAPI definition with redocly
run: |
npm install @redocly/cli -g
redocly lint swagger.yml --config=redocly.yml
diff_swagger:
name: Diff swagger yaml for comment
runs-on: ubuntu-latest
steps:
- name: Use GitHub Token
env:
TOKEN: ${{ secrets.ORG_GH_TOKEN }}
run: >
git config --global url."https://${TOKEN}@github.com".insteadOf "https://github.com"
- name: Checkout repo
uses: TykTechnologies/github-actions/.github/actions/checkout-pr@main
with:
token: ${{ secrets.ORG_GH_TOKEN }}
- name: Setup Golang
uses: actions/setup-go@v5
with:
go-version: stable
- name: Install dyff binary
run: |
# this is the upstream, missing -w (trim whitespace)
# curl --silent --location https://git.io/JYfAY | bash
git clone --depth=1 https://github.com/aoktox/dyff
cd dyff && go install ./cmd/...
- name: Set up comment author
run: |
git config --local user.email "github-actions[bot]@users.noreply.github.com"
git config --local user.name "github-actions[bot]"
- name: Collect
run: |
cp swagger.yml swagger-current.yml
git checkout -- .
git fetch --depth=1 origin ${{ github.base_ref }}
git checkout ${{ github.base_ref }}
cp swagger.yml swagger-prev.yml
- name: Diff
id: api-check
run: |
set +e
dyff between -c on --ignore-whitespace-changes -i swagger-prev.yml swagger-current.yml
dyff between -c off --ignore-whitespace-changes -i swagger-prev.yml swagger-current.yml | egrep -v '^ . ' | sort > changes.txt
LINE_COUNT=$(wc -l < changes.txt)
echo "diff-output<<EOF" >> $GITHUB_OUTPUT
if [ $LINE_COUNT -gt 200 ]; then
echo "Changes in swagger.yml too large (line count ${LINE_COUNT}), check CI lint action for differences" >> $GITHUB_OUTPUT
else
cat changes.txt >> $GITHUB_OUTPUT
fi
echo "EOF" >> $GITHUB_OUTPUT
- name: Find Comment
uses: peter-evans/find-comment@v2
id: fc
with:
issue-number: ${{ github.event.pull_request.number }}
comment-author: 'github-actions[bot]'
body-includes: Swagger Changes
- name: Create or update comment
uses: peter-evans/create-or-update-comment@v3
with:
comment-id: ${{ steps.fc.outputs.comment-id }}
issue-number: ${{ github.event.pull_request.number }}
body: |
Swagger Changes
```diff
${{ steps.api-check.outputs.diff-output || 'no api changes detected' }}
```
edit-mode: replace