feat: simplifier le workflow de vérification des performances en supprimant des étapes inutiles
This commit is contained in:
@@ -1,110 +0,0 @@
|
|||||||
name: Deploy Webzine
|
|
||||||
run-name: Deploy to production by @${{ github.actor }}
|
|
||||||
|
|
||||||
on: [push]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy-production:
|
|
||||||
name: Deploy to Production
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Setup SSH key
|
|
||||||
env:
|
|
||||||
PROD_SSH_KEY: ${{ secrets.PROD_SSH_KEY }}
|
|
||||||
run: |
|
|
||||||
mkdir -p ~/.ssh
|
|
||||||
echo "$PROD_SSH_KEY" > ~/.ssh/id_prod
|
|
||||||
chmod 600 ~/.ssh/id_prod
|
|
||||||
|
|
||||||
echo "=== [DEBUG] Premiers caractères de la clé ==="
|
|
||||||
head -1 ~/.ssh/id_prod
|
|
||||||
tail -1 ~/.ssh/id_prod
|
|
||||||
|
|
||||||
echo "=== [DEBUG] Nombre de lignes ==="
|
|
||||||
wc -l ~/.ssh/id_prod
|
|
||||||
|
|
||||||
echo "=== [DEBUG] Vérification des caractères spéciaux ==="
|
|
||||||
cat -A ~/.ssh/id_prod | head -3
|
|
||||||
cat -A ~/.ssh/id_prod | tail -3
|
|
||||||
|
|
||||||
echo "=== [DEBUG] Validation de la clé avec ssh-keygen ==="
|
|
||||||
ssh-keygen -y -f ~/.ssh/id_prod > /dev/null && echo "Clé valide ✅" || echo "Clé invalide ❌"
|
|
||||||
|
|
||||||
echo "=== [DEBUG] ssh-keyscan sur le serveur ==="
|
|
||||||
ssh-keyscan -v -p ${{ secrets.PROD_SSH_PORT || 22 }} ${{ secrets.PROD_HOST }} >> ~/.ssh/known_hosts 2>&1
|
|
||||||
echo "Exit code ssh-keyscan: $?"
|
|
||||||
|
|
||||||
echo "=== [DEBUG] Contenu known_hosts ==="
|
|
||||||
cat ~/.ssh/known_hosts
|
|
||||||
|
|
||||||
- name: Test SSH connection
|
|
||||||
run: |
|
|
||||||
echo "=== [DEBUG] Test de connexion SSH ==="
|
|
||||||
ssh -v \
|
|
||||||
-i ~/.ssh/id_prod \
|
|
||||||
-p ${{ secrets.PROD_SSH_PORT || 22 }} \
|
|
||||||
-o StrictHostKeyChecking=no \
|
|
||||||
-o ConnectTimeout=10 \
|
|
||||||
${{ secrets.PROD_USER }}@${{ secrets.PROD_HOST }} \
|
|
||||||
"echo 'Connexion SSH OK ✅ — user: $(whoami), host: $(hostname)'" 2>&1
|
|
||||||
echo "Exit code SSH: $?"
|
|
||||||
|
|
||||||
- name: Upload source to server
|
|
||||||
run: |
|
|
||||||
echo "=== [DEBUG] Création de l'archive ==="
|
|
||||||
tar --exclude='.git' --exclude='*.user' -czf /tmp/webzine-src.tar.gz .
|
|
||||||
echo "Taille archive: $(du -sh /tmp/webzine-src.tar.gz | cut -f1)"
|
|
||||||
|
|
||||||
echo "=== [DEBUG] Transfert SCP ==="
|
|
||||||
scp -v \
|
|
||||||
-i ~/.ssh/id_prod \
|
|
||||||
-P ${{ secrets.PROD_SSH_PORT || 22 }} \
|
|
||||||
-o StrictHostKeyChecking=no \
|
|
||||||
-o ConnectTimeout=10 \
|
|
||||||
/tmp/webzine-src.tar.gz \
|
|
||||||
${{ secrets.PROD_USER }}@${{ secrets.PROD_HOST }}:/tmp/webzine-src.tar.gz 2>&1
|
|
||||||
echo "Exit code SCP: $?"
|
|
||||||
|
|
||||||
- name: Build and deploy on PRODUCTION server
|
|
||||||
run: |
|
|
||||||
ssh -i ~/.ssh/id_prod \
|
|
||||||
-p ${{ secrets.PROD_SSH_PORT || 22 }} \
|
|
||||||
-o StrictHostKeyChecking=no \
|
|
||||||
${{ secrets.PROD_USER }}@${{ secrets.PROD_HOST }} << 'ENDSSH'
|
|
||||||
set -e
|
|
||||||
|
|
||||||
echo "=== [PROD] Extraction des sources ==="
|
|
||||||
mkdir -p /opt/webzine/prod/src
|
|
||||||
tar -xzf /tmp/webzine-src.tar.gz -C /opt/webzine/prod/src/
|
|
||||||
rm /tmp/webzine-src.tar.gz
|
|
||||||
|
|
||||||
echo "=== [PROD] Construction de l'image ==="
|
|
||||||
docker build \
|
|
||||||
-t webzine:latest \
|
|
||||||
-f /opt/webzine/prod/src/Webzine.WebApplication/Dockerfile \
|
|
||||||
/opt/webzine/prod/src/
|
|
||||||
|
|
||||||
echo "=== [PROD] Arrêt de l'ancien conteneur ==="
|
|
||||||
docker stop webzine-prod 2>/dev/null || true
|
|
||||||
docker rm webzine-prod 2>/dev/null || true
|
|
||||||
|
|
||||||
echo "=== [PROD] Démarrage du nouveau conteneur ==="
|
|
||||||
docker run -d \
|
|
||||||
--name webzine-prod \
|
|
||||||
--restart unless-stopped \
|
|
||||||
-p 80:8080 \
|
|
||||||
-p 443:8081 \
|
|
||||||
-v /opt/webzine/prod/data:/app/Data \
|
|
||||||
-v /opt/webzine/prod/logs:/Logs \
|
|
||||||
-e ASPNETCORE_ENVIRONMENT=Production \
|
|
||||||
webzine:latest
|
|
||||||
|
|
||||||
echo "=== [PROD] Nettoyage des anciennes images ==="
|
|
||||||
docker image prune -f
|
|
||||||
|
|
||||||
echo "=== [PROD] Déploiement terminé ==="
|
|
||||||
ENDSSH
|
|
||||||
@@ -26,8 +26,7 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
dotnet test Webzine.Entity.Tests/Webzine.Entity.Tests.csproj \
|
dotnet test Webzine.Entity.Tests/Webzine.Entity.Tests.csproj \
|
||||||
--no-build \
|
--no-build \
|
||||||
--configuration Release \
|
--configuration Release
|
||||||
--logger "console;verbosity=normal"
|
|
||||||
|
|
||||||
- name: Start Webzine application
|
- name: Start Webzine application
|
||||||
run: |
|
run: |
|
||||||
@@ -66,7 +65,6 @@ jobs:
|
|||||||
REPO: ${{ gitea.repository }}
|
REPO: ${{ gitea.repository }}
|
||||||
PR_NUMBER: ${{ gitea.event.pull_request.number }}
|
PR_NUMBER: ${{ gitea.event.pull_request.number }}
|
||||||
run: |
|
run: |
|
||||||
# Lire le rapport original
|
|
||||||
RAW_REPORT=$(cat /tmp/webzine_endpoint_output.txt 2>/dev/null || echo "Aucune sortie capturée.")
|
RAW_REPORT=$(cat /tmp/webzine_endpoint_output.txt 2>/dev/null || echo "Aucune sortie capturée.")
|
||||||
FAILED_COUNT="${{ steps.perf_test.outputs.failed }}"
|
FAILED_COUNT="${{ steps.perf_test.outputs.failed }}"
|
||||||
|
|
||||||
@@ -91,27 +89,10 @@ jobs:
|
|||||||
-e 's/^╔\(.*\)╗$/```\n╔\1╗/' \
|
-e 's/^╔\(.*\)╗$/```\n╔\1╗/' \
|
||||||
-e 's/^╚\(.*\)╝$/╚\1╝\n```/')
|
-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."
|
|
||||||
STATUS="❌ ÉCHEC"
|
|
||||||
else
|
|
||||||
HEADER="## ✅ Vérification des performances RÉUSSIE"
|
|
||||||
INTRO="Tous les endpoints ont répondu en moins d'une seconde."
|
|
||||||
STATUS="✅ SUCCÈS"
|
|
||||||
fi
|
|
||||||
|
|
||||||
BODY=$(cat <<EOF
|
BODY=$(cat <<EOF
|
||||||
$HEADER
|
|
||||||
|
|
||||||
$INTRO
|
|
||||||
|
|
||||||
### Rapport complet des tests :
|
|
||||||
|
|
||||||
$FORMATTED_REPORT
|
$FORMATTED_REPORT
|
||||||
|
|
||||||
---
|
---
|
||||||
**Statut**: $STATUS
|
|
||||||
**Seuil**: 1000ms
|
**Seuil**: 1000ms
|
||||||
**Vérifié par**: Workflow PR Endpoint Performance
|
**Vérifié par**: Workflow PR Endpoint Performance
|
||||||
EOF
|
EOF
|
||||||
|
|||||||
@@ -37,9 +37,6 @@ namespace Webzine.WebApplication.Controllers
|
|||||||
return RedirectToAction("Index", "Accueil");
|
return RedirectToAction("Index", "Accueil");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wait 4 second before redirecting to the home page to give the user a chance to see the warning message in the logs.
|
|
||||||
Thread.Sleep(4000);
|
|
||||||
|
|
||||||
// On transforme "fatal-bazooka" en "Fatal Bazooka" pour la factory
|
// On transforme "fatal-bazooka" en "Fatal Bazooka" pour la factory
|
||||||
string nomPropre = System.Globalization.CultureInfo.CurrentCulture.TextInfo
|
string nomPropre = System.Globalization.CultureInfo.CurrentCulture.TextInfo
|
||||||
.ToTitleCase(nom.Replace("-", " "));
|
.ToTitleCase(nom.Replace("-", " "));
|
||||||
|
|||||||
Reference in New Issue
Block a user