-
Notifications
You must be signed in to change notification settings - Fork 7
117 lines (106 loc) · 3.21 KB
/
self-test.yml
File metadata and controls
117 lines (106 loc) · 3.21 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
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
name: Self Test
on:
push:
branches: [main]
paths-ignore:
- '**.md'
- 'docs/**'
- 'assets/**'
- '.github/workflows/release.yml'
- '.github/workflows/example.yml'
- '.github/ISSUE_TEMPLATE/**'
- '.github/PULL_REQUEST_TEMPLATE/**'
- '.gitignore'
- 'LICENSE'
- '.vscode/**'
- '.editorconfig'
pull_request:
branches: [main]
paths-ignore:
- '**.md'
- 'docs/**'
- 'assets/**'
- '.github/workflows/release.yml'
- '.github/workflows/example.yml'
- '.github/ISSUE_TEMPLATE/**'
- '.github/PULL_REQUEST_TEMPLATE/**'
- '.gitignore'
- 'LICENSE'
- '.vscode/**'
- '.editorconfig'
permissions:
contents: read
jobs:
test:
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [22]
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
- run: npm ci
- name: Typecheck
run: npx tsc --noEmit
- name: Unit tests
run: npx vitest run
- name: Build
run: npm run build
- name: Self-scan
run: node dist/bin/g0.js scan . --quiet --json > /dev/null
- name: Verify rule count
run: |
COUNT=$(node -e "
import('./dist/src/index.js')
.then(m => console.log(m.getAllRules().length))
")
echo "Total rules: $COUNT"
if [ "$COUNT" -lt 475 ]; then
echo "ERROR: Expected 475+ rules, got $COUNT"
exit 1
fi
notify:
name: Notify Slack
needs: [test]
runs-on: ubuntu-latest
if: failure() && github.event_name == 'push'
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
SLACK_WEBHOOK_TYPE: INCOMING_WEBHOOK
steps:
- name: Notify Slack - Fail
if: env.SLACK_WEBHOOK_URL != ''
uses: slackapi/slack-github-action@v1.26.0
with:
payload: |
{
"text": "❌ Checks Failed on main",
"blocks": [
{
"type": "header",
"text": { "type": "plain_text", "text": "❌ Checks Failed on main", "emoji": true }
},
{
"type": "section",
"fields": [
{ "type": "mrkdwn", "text": "*Repository:*\n${{ github.repository }}" },
{ "type": "mrkdwn", "text": "*Pushed by:*\n${{ github.actor }}" },
{ "type": "mrkdwn", "text": "*Branch:*\n`main`" },
{ "type": "mrkdwn", "text": "*Commit:*\n<https://github.com/${{ github.repository }}/commit/${{ github.sha }}|${{ github.sha }}>" }
]
},
{
"type": "actions",
"elements": [
{
"type": "button",
"text": { "type": "plain_text", "text": "View Logs" },
"url": "https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}",
"style": "danger"
}
]
}
]
}