refactor : mettre à jour les commentaires français pour plus de clarté et de cohérence dans le déploiement et les workflows de vérification des points de terminaison PR

This commit is contained in:
mirage
2026-03-26 15:20:51 +01:00
parent 45b91d4c98
commit b2264714e2
2 changed files with 29 additions and 82 deletions

View File

@@ -4,11 +4,10 @@ on:
push: push:
branches: branches:
- main - main
- dev
jobs: jobs:
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# BUILD — commun aux deux branches # COMPILATION — commun aux deux branches
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
build: build:
name: Build & Push Docker Image name: Build & Push Docker Image
@@ -20,17 +19,11 @@ jobs:
# Le tag d'image dépend de la branche : # Le tag d'image dépend de la branche :
# main → webzine:latest # main → webzine:latest
# dev → webzine:dev
- name: Set image tag - name: Set image tag
id: vars id: vars
run: | run: |
if [ "${{ gitea.ref_name }}" = "main" ]; then
echo "IMAGE_TAG=latest" >> $GITHUB_OUTPUT echo "IMAGE_TAG=latest" >> $GITHUB_OUTPUT
echo "ENV_LABEL=production" >> $GITHUB_OUTPUT echo "ENV_LABEL=production" >> $GITHUB_OUTPUT
else
echo "IMAGE_TAG=dev" >> $GITHUB_OUTPUT
echo "ENV_LABEL=development" >> $GITHUB_OUTPUT
fi
- name: Set up Docker Buildx - name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3 uses: docker/setup-buildx-action@v3
@@ -43,6 +36,7 @@ jobs:
username: ${{ secrets.REGISTRY_USERNAME }} username: ${{ secrets.REGISTRY_USERNAME }}
password: ${{ secrets.REGISTRY_PASSWORD }} password: ${{ secrets.REGISTRY_PASSWORD }}
# Construction et publication de l'image Docker
- name: Build and push Docker image - name: Build and push Docker image
uses: docker/build-push-action@v5 uses: docker/build-push-action@v5
with: with:
@@ -58,12 +52,11 @@ jobs:
env_label: ${{ steps.vars.outputs.ENV_LABEL }} env_label: ${{ steps.vars.outputs.ENV_LABEL }}
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# DEPLOY — Machine de PRODUCTION (branche main) # DÉPLOIEMENT — Serveur de PRODUCTION (branche main)
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
deploy-production: deploy-production:
name: Deploy to Production name: Deploy to Production
needs: build needs: build
if: gitea.ref_name == 'main'
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
@@ -77,18 +70,18 @@ jobs:
script: | script: |
set -e set -e
echo "=== [PROD] Pulling image ===" echo "=== [PROD] Récupération de l'image ==="
docker login ${{ vars.REGISTRY_URL }} \ docker login ${{ vars.REGISTRY_URL }} \
-u ${{ secrets.REGISTRY_USERNAME }} \ -u ${{ secrets.REGISTRY_USERNAME }} \
-p ${{ secrets.REGISTRY_PASSWORD }} -p ${{ secrets.REGISTRY_PASSWORD }}
docker pull ${{ vars.REGISTRY_URL }}/webzine/webzine:latest docker pull ${{ vars.REGISTRY_URL }}/webzine/webzine:latest
echo "=== [PROD] Stopping old container ===" echo "=== [PROD] Arrêt de l'ancien conteneur ==="
docker stop webzine-prod 2>/dev/null || true docker stop webzine-prod 2>/dev/null || true
docker rm webzine-prod 2>/dev/null || true docker rm webzine-prod 2>/dev/null || true
echo "=== [PROD] Starting new container ===" echo "=== [PROD] Démarrage du nouveau conteneur ==="
docker run -d \ docker run -d \
--name webzine-prod \ --name webzine-prod \
--restart unless-stopped \ --restart unless-stopped \
@@ -99,53 +92,7 @@ jobs:
-e ASPNETCORE_ENVIRONMENT=Production \ -e ASPNETCORE_ENVIRONMENT=Production \
${{ vars.REGISTRY_URL }}/webzine/webzine:latest ${{ vars.REGISTRY_URL }}/webzine/webzine:latest
echo "=== [PROD] Cleaning up old images ===" echo "=== [PROD] Nettoyage des anciennes images ==="
docker image prune -f docker image prune -f
echo "=== [PROD] Deployment complete ===" echo "=== [PROD] Déploiement terminé ==="
# ─────────────────────────────────────────────
# DEPLOY — Machine de DÉVELOPPEMENT (branche dev)
# ─────────────────────────────────────────────
deploy-development:
name: Deploy to Development
needs: build
if: gitea.ref_name == 'dev'
runs-on: ubuntu-latest
steps:
- name: Deploy via SSH to DEVELOPMENT server
uses: appleboy/ssh-action@v1.0.3
with:
host: ${{ secrets.DEV_SSH_HOST }}
username: ${{ secrets.DEV_SSH_USER }}
key: ${{ secrets.DEV_SSH_KEY }}
port: ${{ secrets.DEV_SSH_PORT || 22 }}
script: |
set -e
echo "=== [DEV] Pulling image ==="
docker login ${{ vars.REGISTRY_URL }} \
-u ${{ secrets.REGISTRY_USERNAME }} \
-p ${{ secrets.REGISTRY_PASSWORD }}
docker pull ${{ vars.REGISTRY_URL }}/webzine/webzine:dev
echo "=== [DEV] Stopping old container ==="
docker stop webzine-dev 2>/dev/null || true
docker rm webzine-dev 2>/dev/null || true
echo "=== [DEV] Starting new container ==="
docker run -d \
--name webzine-dev \
--restart unless-stopped \
-p 8080:8080 \
-v /opt/webzine/dev/data:/app/Data \
-v /opt/webzine/dev/logs:/Logs \
-e ASPNETCORE_ENVIRONMENT=Development \
${{ vars.REGISTRY_URL }}/webzine/webzine:dev
echo "=== [DEV] Cleaning up old images ==="
docker image prune -f
echo "=== [DEV] Deployment complete ==="

View File

@@ -14,13 +14,13 @@ jobs:
steps: steps:
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# 1. Checkout code # Récupération du code source
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
- name: Checkout PR branch - name: Checkout PR branch
uses: actions/checkout@v4 uses: actions/checkout@v4
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# 2. Setup .NET 10 # Installation de .NET 10
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
- name: Setup .NET 10 - name: Setup .NET 10
uses: actions/setup-dotnet@v4 uses: actions/setup-dotnet@v4
@@ -28,7 +28,7 @@ jobs:
dotnet-version: "10.0.x" dotnet-version: "10.0.x"
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# 3. Restore & Build # Restauration des dépendances et compilation
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
- name: Restore dependencies - name: Restore dependencies
run: dotnet restore Webzine.sln run: dotnet restore Webzine.sln
@@ -37,7 +37,7 @@ jobs:
run: dotnet build Webzine.sln --no-restore --configuration Release run: dotnet build Webzine.sln --no-restore --configuration Release
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# 4. Run unit tests (entity tests) # Exécution des tests unitaires (entités)
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
- name: Run unit tests - name: Run unit tests
run: | run: |
@@ -47,7 +47,7 @@ jobs:
--logger "console;verbosity=normal" --logger "console;verbosity=normal"
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# 5. Start the web application in background # Démarrage de l'application web en arrière-plan
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
- name: Start Webzine application - name: Start Webzine application
run: | run: |
@@ -57,16 +57,16 @@ jobs:
--no-build \ --no-build \
-- --urls "http://localhost:5038" & -- --urls "http://localhost:5038" &
echo "Waiting for application to start..." echo "Attente du démarrage de l'application..."
timeout 60 bash -c ' timeout 60 bash -c '
until curl -sf http://localhost:5038 > /dev/null 2>&1; do until curl -sf http://localhost:5038 > /dev/null 2>&1; do
sleep 1 sleep 1
done done
' '
echo "Application is ready!" echo "Application prête !"
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# 6. Run endpoint performance tests # Exécution des tests de performance des endpoints
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
- name: Test endpoint response times - name: Test endpoint response times
id: perf_test id: perf_test
@@ -77,7 +77,7 @@ jobs:
echo "failed=$FAIL_COUNT" >> "$GITHUB_OUTPUT" echo "failed=$FAIL_COUNT" >> "$GITHUB_OUTPUT"
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# 7. Post report as PR comment # Publication du rapport en commentaire de PR
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
- name: Post performance report as PR comment - name: Post performance report as PR comment
if: always() if: always()
@@ -87,15 +87,15 @@ jobs:
REPO: ${{ gitea.repository }} REPO: ${{ gitea.repository }}
PR_NUMBER: ${{ gitea.event.pull_request.number }} PR_NUMBER: ${{ gitea.event.pull_request.number }}
run: | run: |
REPORT_CONTENT=$(cat /tmp/webzine_endpoint_report.txt 2>/dev/null || echo "No report generated.") REPORT_CONTENT=$(cat /tmp/webzine_endpoint_report.txt 2>/dev/null || echo "Aucun rapport généré.")
FAILED_COUNT="${{ steps.perf_test.outputs.failed }}" FAILED_COUNT="${{ steps.perf_test.outputs.failed }}"
if [ "${FAILED_COUNT:-0}" -gt 0 ]; then if [ "${FAILED_COUNT:-0}" -gt 0 ]; then
HEADER="## ❌ Performance Check FAILED" HEADER="## ❌ Vérification des performances ÉCHOUÉE"
INTRO="${FAILED_COUNT} endpoint(s) exceeded 1 second or returned a server error." INTRO="${FAILED_COUNT} endpoint(s) ont dépassé 1 seconde ou retourné une erreur serveur."
else else
HEADER="## ✅ Performance Check PASSED" HEADER="## ✅ Vérification des performances RÉUSSIE"
INTRO="All endpoints responded in under 1 second." INTRO="Tous les endpoints ont répondu en moins d'une seconde."
fi fi
BODY=$(cat <<EOF BODY=$(cat <<EOF
@@ -107,7 +107,7 @@ jobs:
$REPORT_CONTENT $REPORT_CONTENT
\`\`\` \`\`\`
> Threshold: **1000ms** | Checked by the **PR Endpoint Performance** workflow. > Seuil : **1000ms** | Vérifié par le workflow **PR Endpoint Performance**.
EOF EOF
) )
@@ -118,15 +118,15 @@ jobs:
"$GITEA_SERVER_URL/api/v1/repos/$REPO/issues/$PR_NUMBER/comments" "$GITEA_SERVER_URL/api/v1/repos/$REPO/issues/$PR_NUMBER/comments"
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
# 8. Fail the job if any endpoint failed # Blocage de la PR si un endpoint a échoué
# ───────────────────────────────────────────── # ─────────────────────────────────────────────
- name: Enforce performance gate - name: Enforce performance gate
run: | run: |
FAILED="${{ steps.perf_test.outputs.failed }}" FAILED="${{ steps.perf_test.outputs.failed }}"
if [ "${FAILED:-0}" -gt 0 ]; then if [ "${FAILED:-0}" -gt 0 ]; then
echo "❌ PR REJECTED: ${FAILED} endpoint(s) failed the 1-second threshold." echo "❌ PR REJETÉE : ${FAILED} endpoint(s) n'ont pas respecté le seuil d'une seconde."
echo " Fix the slow/failing endpoints listed above before merging." echo " Corrigez les endpoints lents ou en erreur avant de fusionner."
exit 1 exit 1
else else
echo "✅ All endpoints passed the performance gate." echo "✅ Tous les endpoints ont passé le contrôle de performance."
fi fi