ci: add coverage summary printed to job log
All checks were successful
CI / Lint, type check, unit tests, coverage (push) Successful in 2m6s
CI / E2E browser tests (push) Successful in 44s

Adds a step after backend coverage that parses the JaCoCo XML report
and prints a formatted table showing line and branch coverage with
pass/fail status against thresholds (70% lines, 60% branches).

The frontend coverage is already visible from Vitest's built-in text
reporter which prints during npm run test:coverage.

Both HTML reports remain downloadable as artifacts (backend-coverage
and frontend-coverage ZIPs).

Result: coverage numbers are visible at a glance in the CI job log
without needing to download and unzip artifacts.
This commit is contained in:
Joakim Mörling 2026-05-19 20:30:19 +02:00
parent 4a48dccd91
commit 5705b17c4b

View file

@ -42,6 +42,39 @@ jobs:
- name: Backend coverage
run: ./gradlew :backend:jacocoTestCoverageVerification
- name: Print coverage summary
run: |
node -e "
const fs = require('fs');
const xml = fs.readFileSync('backend/build/reports/jacoco/test/jacocoTestReport.xml', 'utf8');
const lineMatch = xml.match(/<counter type=\"LINE\" missed=\"(\d+)\" covered=\"(\d+)\"\\/>/g);
const branchMatch = xml.match(/<counter type=\"BRANCH\" missed=\"(\d+)\" covered=\"(\d+)\"\\/>/g);
if (lineMatch && branchMatch) {
const lastLine = lineMatch[lineMatch.length - 1].match(/missed=\"(\d+)\" covered=\"(\d+)\"/);
const lastBranch = branchMatch[branchMatch.length - 1].match(/missed=\"(\d+)\" covered=\"(\d+)\"/);
const lineMissed = +lastLine[1], lineCovered = +lastLine[2];
const branchMissed = +lastBranch[1], branchCovered = +lastBranch[2];
const linePct = (lineCovered / (lineMissed + lineCovered) * 100).toFixed(1);
const branchPct = (branchCovered / (branchMissed + branchCovered) * 100).toFixed(1);
const lineStatus = linePct >= 70 ? '✅' : '❌';
const branchStatus = branchPct >= 60 ? '✅' : '❌';
console.log('');
console.log('╔══════════════════════════════════════════════════════╗');
console.log('║ Coverage Summary — Bilhej ║');
console.log('╠══════════════════════╦══════════╦══════════╦═════════╣');
console.log('║ Layer │ Lines │ Branch │ Status ║');
console.log('╠══════════════════════╬══════════╬══════════╬═════════╣');
console.log('║ Backend │ ' + linePct.padStart(6) + '% │ ' + branchPct.padStart(6) + '% │ ' + lineStatus + ' ' + branchStatus + ' ║');
console.log('╠══════════════════════╬══════════╬══════════╬═════════╣');
console.log('║ Thresholds │ 70.0% │ 60.0% │ ║');
console.log('╚══════════════════════╩══════════╩══════════╩═════════╝');
console.log('');
console.log('Frontend coverage printed above by Vitest text reporter.');
console.log('Download full HTML reports from the Artifacts tab.');
console.log('');
}
"
- name: Frontend coverage
run: npm run test:coverage
working-directory: frontend