-
Notifications
You must be signed in to change notification settings - Fork 0
170 lines (152 loc) · 6.82 KB
/
Copy pathblackroad-ci.yml
File metadata and controls
170 lines (152 loc) · 6.82 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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
name: BlackRoad CI
on:
push:
branches: [main, master]
pull_request:
branches: [main, master]
workflow_dispatch:
permissions:
contents: read
checks: write
jobs:
ci:
name: CI
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Detect and validate
id: detect
run: |
ERRORS=0
WARNINGS=0
SUMMARY=""
echo "## BlackRoad CI Report" >> $GITHUB_STEP_SUMMARY
echo "**Repo:** \`${{ github.repository }}\`" >> $GITHUB_STEP_SUMMARY
echo "**Branch:** \`${{ github.ref_name }}\`" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
# ---- Shell scripts ----
SHELL_FILES=$(find . -name "*.sh" -not -path "./.git/*" -not -path "./node_modules/*" -not -path "./.venv/*" 2>/dev/null)
SHELL_COUNT=$(echo "$SHELL_FILES" | grep -c . 2>/dev/null || echo 0)
if [ "$SHELL_COUNT" -gt 0 ]; then
echo "### Shell ($SHELL_COUNT files)" >> $GITHUB_STEP_SUMMARY
SYNTAX_FAIL=0
while IFS= read -r f; do
[ -z "$f" ] && continue
if ! bash -n "$f" 2>/dev/null; then
echo "- Syntax error: \`$f\`" >> $GITHUB_STEP_SUMMARY
SYNTAX_FAIL=$((SYNTAX_FAIL+1))
fi
done <<< "$SHELL_FILES"
if [ "$SYNTAX_FAIL" -eq 0 ]; then
echo "- All $SHELL_COUNT scripts pass syntax check" >> $GITHUB_STEP_SUMMARY
else
WARNINGS=$((WARNINGS+SYNTAX_FAIL))
fi
echo "" >> $GITHUB_STEP_SUMMARY
fi
# ---- Node.js ----
if [ -f package.json ]; then
PKG_NAME=$(node -e "try{console.log(require('./package.json').name||'unnamed')}catch{console.log('parse-error')}" 2>/dev/null)
echo "### Node.js (\`$PKG_NAME\`)" >> $GITHUB_STEP_SUMMARY
# Check if package.json is valid JSON
if ! node -e "JSON.parse(require('fs').readFileSync('package.json','utf8'))" 2>/dev/null; then
echo "- Invalid package.json" >> $GITHUB_STEP_SUMMARY
ERRORS=$((ERRORS+1))
else
# Check for lockfile
if [ -f package-lock.json ] || [ -f yarn.lock ] || [ -f pnpm-lock.yaml ]; then
echo "- Lockfile present" >> $GITHUB_STEP_SUMMARY
fi
# Only run tests if there's a real test script
HAS_TEST=$(node -e "const p=require('./package.json');const t=p.scripts?.test||'';console.log(t&&!t.includes('no test specified')?'yes':'no')" 2>/dev/null)
if [ "$HAS_TEST" = "yes" ]; then
echo "- Test script found, running..." >> $GITHUB_STEP_SUMMARY
fi
fi
echo "" >> $GITHUB_STEP_SUMMARY
fi
# ---- Python ----
PY_FILES=$(find . -name "*.py" -not -path "./.git/*" -not -path "./node_modules/*" -not -path "./.venv/*" -not -path "./env/*" 2>/dev/null)
PY_COUNT=$(echo "$PY_FILES" | grep -c . 2>/dev/null || echo 0)
if [ "$PY_COUNT" -gt 0 ]; then
echo "### Python ($PY_COUNT files)" >> $GITHUB_STEP_SUMMARY
SYNTAX_FAIL=0
while IFS= read -r f; do
[ -z "$f" ] && continue
if ! python3 -c "import ast; ast.parse(open('$f').read())" 2>/dev/null; then
echo "- Syntax error: \`$f\`" >> $GITHUB_STEP_SUMMARY
SYNTAX_FAIL=$((SYNTAX_FAIL+1))
fi
done <<< "$(echo "$PY_FILES" | head -50)"
if [ "$SYNTAX_FAIL" -eq 0 ]; then
echo "- All files pass syntax check" >> $GITHUB_STEP_SUMMARY
else
WARNINGS=$((WARNINGS+SYNTAX_FAIL))
fi
echo "" >> $GITHUB_STEP_SUMMARY
fi
# ---- Go ----
if [ -f go.mod ]; then
echo "### Go" >> $GITHUB_STEP_SUMMARY
GO_MOD=$(head -1 go.mod)
echo "- Module: \`$GO_MOD\`" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
fi
# ---- HTML ----
HTML_COUNT=$(find . -name "*.html" -not -path "./.git/*" -not -path "./node_modules/*" -not -path "./dist/*" -not -path "./.next/*" | wc -l 2>/dev/null)
if [ "$HTML_COUNT" -gt 0 ]; then
echo "### HTML ($HTML_COUNT files)" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
fi
# ---- Rust ----
if [ -f Cargo.toml ]; then
echo "### Rust" >> $GITHUB_STEP_SUMMARY
CRATE=$(grep '^name' Cargo.toml | head -1 | cut -d'"' -f2)
echo "- Crate: \`$CRATE\`" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
fi
# ---- Dockerfile ----
if [ -f Dockerfile ] || [ -f docker-compose.yml ] || [ -f docker-compose.yaml ]; then
echo "### Docker" >> $GITHUB_STEP_SUMMARY
[ -f Dockerfile ] && echo "- Dockerfile present" >> $GITHUB_STEP_SUMMARY
[ -f docker-compose.yml ] || [ -f docker-compose.yaml ] && echo "- Compose file present" >> $GITHUB_STEP_SUMMARY
echo "" >> $GITHUB_STEP_SUMMARY
fi
# ---- Summary ----
echo "---" >> $GITHUB_STEP_SUMMARY
if [ "$ERRORS" -gt 0 ]; then
echo "**Result: $ERRORS errors, $WARNINGS warnings**" >> $GITHUB_STEP_SUMMARY
elif [ "$WARNINGS" -gt 0 ]; then
echo "**Result: $WARNINGS warnings (non-blocking)**" >> $GITHUB_STEP_SUMMARY
else
echo "**Result: Passed**" >> $GITHUB_STEP_SUMMARY
fi
echo "*BlackRoad OS, Inc. | [blackroad.io](https://blackroad.io)*" >> $GITHUB_STEP_SUMMARY
# Only run npm tests if package.json exists with a real test script
- name: Setup Node.js
if: hashFiles('package.json') != ''
uses: actions/setup-node@v6
with:
node-version: 22
continue-on-error: true
- name: Install dependencies
if: hashFiles('package.json') != ''
run: |
if [ -f package-lock.json ]; then
npm ci --ignore-scripts 2>/dev/null || npm install --ignore-scripts 2>/dev/null || true
elif [ -f yarn.lock ]; then
yarn install --frozen-lockfile --ignore-scripts 2>/dev/null || true
else
npm install --ignore-scripts 2>/dev/null || true
fi
continue-on-error: true
- name: Run tests
if: hashFiles('package.json') != ''
run: |
HAS_TEST=$(node -e "const p=require('./package.json');const t=p.scripts?.test||'';console.log(t&&!t.includes('no test specified')?'yes':'no')" 2>/dev/null)
if [ "$HAS_TEST" = "yes" ]; then
npm test 2>&1 || echo "Tests reported failures (see above)"
else
echo "No test script configured, skipping"
fi
continue-on-error: true