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:
@@ -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 ==="
|
|
||||||
@@ -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
|
||||||
Reference in New Issue
Block a user