feat: améliorer le rapport de performance en simplifiant le traitement des résultats et en ajustant le format Markdown

This commit is contained in:
mirage
2026-03-27 10:44:03 +01:00
parent 3e89693b08
commit e012bc4dbd

View File

@@ -49,14 +49,11 @@ jobs:
id: perf_test
run: |
chmod +x scripts/test-endpoints.sh
bash scripts/test-endpoints.sh http://localhost:5038 1000 2>&1 | tee /tmp/webzine_endpoint_output.txt
EXIT_CODE=${PIPESTATUS[0]}
FAIL_COUNT=$(grep -c "\[ÉCHEC\]\|\[LENT\]" /tmp/webzine_endpoint_output.txt || echo 0)
bash scripts/test-endpoints.sh http://localhost:5038 1000 2>&1 \
| tee /tmp/webzine_endpoint_output.txt || true
FAIL_COUNT=$(grep -cE "^\[(LENT|ÉCHEC)\]" /tmp/webzine_rapport_endpoints.txt 2>/dev/null || echo 0)
echo "failed=$FAIL_COUNT" >> "$GITHUB_OUTPUT"
echo "exit_code=$EXIT_CODE" >> "$GITHUB_OUTPUT"
exit $EXIT_CODE
- name: Post performance report as PR comment
if: always()
@@ -66,29 +63,27 @@ jobs:
REPO: ${{ gitea.repository }}
PR_NUMBER: ${{ gitea.event.pull_request.number }}
run: |
# Lire le rapport original
RAW_REPORT=$(cat /tmp/webzine_endpoint_output.txt)
RAW_REPORT=$(cat /tmp/webzine_endpoint_output.txt 2>/dev/null || echo "Aucune sortie capturée.")
FAILED_COUNT="${{ steps.perf_test.outputs.failed }}"
# Convertir le rapport ANSI en Markdown avec couleurs
# Supprimer d'abord les codes ANSI pour le traitement
CLEAN_REPORT=$(echo "$RAW_REPORT" | sed 's/\x1b\[[0-9;]*m//g')
# Générer le rapport formaté en Markdown avec couleurs
FORMATTED_REPORT=$(echo "$CLEAN_REPORT" | sed \
-e 's/^\[OK\] /✅ /' \
-e 's/^\[LENT\] /⚠️ /' \
-e 's/^\[ÉCHEC\] /❌ /' \
-e 's/^── \(.*\)$/\n### ── \1/' \
-e 's/^→/ •/' \
-e 's/^\(Total.*\)$/\n**\1**/' \
-e 's/^\(Réussis.*\)$/**✅ \1**/' \
-e 's/^\(Échecs.*\)$/**\1**/' \
-e 's/^\(❌ ENDPOINTS EN ÉCHEC.*\)$/\n### \1/' \
-e 's/^\(La PR doit.*\)$/\n**❌ \1**/' \
-e 's/^\(.*\)$/```\n╔\1/' \
-e 's/^\(.*\)$/╚\1╝\n```/')
-e 's/^\[OK\] /✅ /' \
-e 's/^\[LENT\] /⚠️ /' \
-e 's/^\[ÉCHEC\] /❌ /' \
-e 's/^→ \[LENT\] / • ⚠️ /' \
-e 's/^→ \[ÉCHEC\] / •/' \
-e 's/^→ / • /' \
-e 's/^── \(.*\)$/\n### ── \1/' \
-e 's/^\(Total.*\)$/\n**\1**/' \
-e 's/^\(Réussis.*\)$/**✅ \1**/' \
-e 's/^\(Échecs.*\)$/**❌ \1**/' \
-e 's/^\(❌ ENDPOINTS EN ÉCHEC.*\)$/\n### \1/' \
-e 's/^\(La PR doit.*\)$/\n**❌ \1**/' \
-e 's/^╔\(.*\)╗$/```\n╔\1╗/' \
-e 's/^╚\(.*\)╝$/╚\1╝\n```/')
if [ "${FAILED_COUNT:-0}" -gt 0 ]; then
HEADER="## ❌ Vérification des performances ÉCHOUÉE"
INTRO="${FAILED_COUNT} endpoint(s) ont dépassé 1 seconde ou retourné une erreur serveur."
@@ -98,55 +93,36 @@ jobs:
INTRO="Tous les endpoints ont répondu en moins d'une seconde."
STATUS="✅ SUCCÈS"
fi
BODY=$(cat <<EOF
$HEADER
$INTRO
### Rapport complet des tests :
$FORMATTED_REPORT
---
**Statut**: $STATUS
**Seuil**: 1000ms
**Vérifié par**: Workflow PR Endpoint Performance
EOF
)
curl -s -X POST \
$HEADER
$INTRO
### Rapport complet des tests :
$FORMATTED_REPORT
---
**Statut**: $STATUS
**Seuil**: 1000ms
**Vérifié par**: Workflow PR Endpoint Performance
EOF
)
curl -s -X POST \
-H "Authorization: token $GITEA_TOKEN" \
-H "Content-Type: application/json" \
-d "$(jq -n --arg body "$BODY" '{body: $body}')" \
"$GITEA_SERVER_URL/api/v1/repos/$REPO/issues/$PR_NUMBER/comments"
mkdir -p /tmp/artifacts
cp /tmp/webzine_endpoint_output.txt /tmp/artifacts/performance-report.txt
"$GITEA_SERVER_URL/api/v1/repos/$REPO/issues/$PR_NUMBER/comments"
- name: Upload performance report
if: always()
uses: actions/upload-artifact@v3
with:
name: performance-report
path: /tmp/artifacts/
retention-days: 7
- name: Enforce performance gate
if: always()
run: |
FAILED="${{ steps.perf_test.outputs.failed }}"
if [ "${FAILED:-0}" -gt 0 ]; then
echo "❌ PR REJETÉE : ${FAILED} endpoint(s) n'ont pas respecté le seuil d'une seconde."
echo " Corrigez les endpoints lents ou en erreur avant de fusionner."
echo ""
echo "Résumé des problèmes :"
if [ -f /tmp/webzine_endpoint_output.txt ]; then
grep -E "\[ÉCHEC\]|\[LENT\]" /tmp/webzine_endpoint_output.txt || echo " (aucun détail disponible)"
else
echo " (fichier de rapport non disponible)"
fi
exit 1
else
echo "✅ Tous les endpoints ont passé le contrôle de performance."
fi
- name: Enforce performance gate
if: always()
run: |
FAILED="${{ steps.perf_test.outputs.failed }}"
if [ "${FAILED:-0}" -gt 0 ]; then
echo "❌ PR REJETÉE : ${FAILED} endpoint(s) n'ont pas respecté le seuil d'une seconde."
exit 1
else
echo "✅ Tous les endpoints ont passé le contrôle de performance."
fi