bats coverage fix
This commit is contained in:
@@ -7,8 +7,12 @@ REPORT_DIR="${2:-}"
|
|||||||
[ -n "$COVERAGE_VOLUME" ] || { echo "ERROR: coverage volume name required" >&2; exit 1; }
|
[ -n "$COVERAGE_VOLUME" ] || { echo "ERROR: coverage volume name required" >&2; exit 1; }
|
||||||
[ -n "$REPORT_DIR" ] || { echo "ERROR: report directory required" >&2; exit 1; }
|
[ -n "$REPORT_DIR" ] || { echo "ERROR: report directory required" >&2; exit 1; }
|
||||||
|
|
||||||
mkdir -p "$REPORT_DIR/coverage"
|
HAS_COVERAGE=false
|
||||||
docker run --rm -v "$COVERAGE_VOLUME":/coverage alpine tar c -C /coverage . | tar x -C "$REPORT_DIR/coverage"
|
if docker run --rm -v "$COVERAGE_VOLUME":/coverage alpine sh -c '[ -d /coverage ] && ls -A /coverage | grep -q .' 2>/dev/null; then
|
||||||
|
mkdir -p "$REPORT_DIR/coverage"
|
||||||
|
docker run --rm -v "$COVERAGE_VOLUME":/coverage alpine tar c -C /coverage . | tar x -C "$REPORT_DIR/coverage"
|
||||||
|
HAS_COVERAGE=true
|
||||||
|
fi
|
||||||
|
|
||||||
cat > "$REPORT_DIR/index.html" << EOF
|
cat > "$REPORT_DIR/index.html" << EOF
|
||||||
<!DOCTYPE html><html lang="en"><head><meta charset="utf-8">
|
<!DOCTYPE html><html lang="en"><head><meta charset="utf-8">
|
||||||
@@ -19,7 +23,10 @@ h1{color:#1e293b}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:un
|
|||||||
<h1>Bats report <code>${GITHUB_SHA:0:8}</code></h1>
|
<h1>Bats report <code>${GITHUB_SHA:0:8}</code></h1>
|
||||||
<ul>
|
<ul>
|
||||||
<li><a href="test-report.html">Test results</a></li>
|
<li><a href="test-report.html">Test results</a></li>
|
||||||
<li><a href="coverage/index.html">Coverage report</a></li>
|
|
||||||
</ul>
|
|
||||||
</body></html>
|
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
if [ "$HAS_COVERAGE" = true ]; then
|
||||||
|
echo '<li><a href="coverage/index.html">Coverage report</a></li>' >> "$REPORT_DIR/index.html"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo '</ul></body></html>' >> "$REPORT_DIR/index.html"
|
||||||
|
|||||||
@@ -7,8 +7,8 @@ OUTPUT="$REPORT_DIR/test-report.html"
|
|||||||
|
|
||||||
[ -f "$INPUT" ] || { echo "ERROR: $INPUT not found" >&2; exit 1; }
|
[ -f "$INPUT" ] || { echo "ERROR: $INPUT not found" >&2; exit 1; }
|
||||||
|
|
||||||
TOTAL=$(grep -cE '^(ok|not ok) ' "$INPUT" 2>/dev/null || echo 0)
|
TOTAL=$(grep -cE '^(ok|not ok) ' "$INPUT" 2>/dev/null) || TOTAL=0
|
||||||
PASS=$(grep -c '^ok ' "$INPUT" 2>/dev/null || echo 0)
|
PASS=$(grep -c '^ok ' "$INPUT" 2>/dev/null) || PASS=0
|
||||||
FAIL=$((TOTAL - PASS))
|
FAIL=$((TOTAL - PASS))
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -59,8 +59,12 @@ jobs:
|
|||||||
-v bats-workspace:/data \
|
-v bats-workspace:/data \
|
||||||
-v bats-coverage:/coverage \
|
-v bats-coverage:/coverage \
|
||||||
--entrypoint bash ${{ inputs.bats-image }} \
|
--entrypoint bash ${{ inputs.bats-image }} \
|
||||||
-c 'apk add -q lsof python3 jq curl kcov && \
|
-c 'apk add -q lsof python3 jq curl && \
|
||||||
cd /data && kcov --include-path=/data/scripts/ /coverage/ bats tests/' \
|
if apk add -q kcov 2>/dev/null; then \
|
||||||
|
kcov --include-path=/data/scripts/ /coverage/ bats tests/; \
|
||||||
|
else \
|
||||||
|
echo "kcov not available, skipping coverage" >&2 && bats tests/; \
|
||||||
|
fi' \
|
||||||
> "reports/${GITHUB_SHA:0:8}/bats/results.txt" 2>&1
|
> "reports/${GITHUB_SHA:0:8}/bats/results.txt" 2>&1
|
||||||
BATS_EXIT=$?
|
BATS_EXIT=$?
|
||||||
bash .ci/.gitea/scripts/bats-coverage.sh bats-coverage "reports/${GITHUB_SHA:0:8}/bats"
|
bash .ci/.gitea/scripts/bats-coverage.sh bats-coverage "reports/${GITHUB_SHA:0:8}/bats"
|
||||||
|
|||||||
Reference in New Issue
Block a user