Fix Jenkinsfile syntax (clean comments)

This commit is contained in:
soufiane 2025-11-04 15:17:49 +01:00
parent 7ec762cb3d
commit 303307092f

96
Jenkinsfile vendored
View File

@ -1,14 +1,11 @@
pipeline { pipeline {
agent any agent any
// 🔁 Vérifie toutes les 2 minutes si du nouveau code a été poussé
triggers { }
parameters { parameters {
choice( choice(
name: 'ENV', name: 'ENV',
choices: ['dev', 'preprod', 'prod'], choices: ['dev', 'preprod', 'prod'],
description: 'Choisir lenvironnement de déploiement' description: 'Choisir lenvironnement de déploiement'
) )
} }
@ -19,14 +16,12 @@ pipeline {
stages { stages {
// ─────────────────────────────── // Stage 1: Initialisation
// 1⃣ Init — Détection automatique de lenvironnement
// ───────────────────────────────
stage('Init') { stage('Init') {
steps { steps {
script { script {
def currentBranch = sh(script: "git rev-parse --abbrev-ref HEAD", returnStdout: true).trim() def currentBranch = sh(script: "git rev-parse --abbrev-ref HEAD", returnStdout: true).trim()
echo "🧭 Branche détectée : ${currentBranch}" echo "Branche détectée : ${currentBranch}"
if (["dev", "preprod", "main"].contains(currentBranch)) { if (["dev", "preprod", "main"].contains(currentBranch)) {
env.ENV = (currentBranch == "main") ? "prod" : currentBranch env.ENV = (currentBranch == "main") ? "prod" : currentBranch
@ -36,31 +31,18 @@ pipeline {
env.TAG = "${env.ENV}-latest" env.TAG = "${env.ENV}-latest"
env.DEPLOY_PATH = "/srv/devops/the-tip-top/${env.ENV}" env.DEPLOY_PATH = "/srv/devops/the-tip-top/${env.ENV}"
echo """
🌍 Environnement = ${env.ENV}
🏷️ Tag Docker = ${env.TAG}
📂 Chemin de déploiement = ${env.DEPLOY_PATH}
"""
sh "ls -l ${env.DEPLOY_PATH} || echo '⚠️ Dossier non accessible depuis Jenkins'"
} }
} }
} }
// ─────────────────────────────── // Stage 2: Checkout du code
// 2⃣ Checkout du code
// ───────────────────────────────
stage('Checkout') { stage('Checkout') {
steps { steps {
echo "📦 Récupération du code source depuis Gitea..."
checkout scm checkout scm
} }
} }
// ─────────────────────────────── // Stage 3: Tests et Qualité
// 3⃣ Tests & Qualité
// ───────────────────────────────
stage('Tests & Qualité') { stage('Tests & Qualité') {
agent { agent {
docker { docker {
@ -69,21 +51,17 @@ pipeline {
} }
} }
steps { steps {
echo "🧪 Lancement des tests et analyse de code..."
sh ''' sh '''
npm ci npm ci
npm run lint || echo "⚠️ Erreurs de lint détectées" npm run lint || echo "Erreurs de lint détectées"
npm test || echo "⚠️ Tests échoués — vérifier les logs" npm test || echo "Tests échoués"
''' '''
} }
} }
// ─────────────────────────────── // Stage 4: Build Docker image
// 4⃣ Build Docker image
// ───────────────────────────────
stage('Build Docker image') { stage('Build Docker image') {
steps { steps {
echo "🐳 Construction de limage Docker backend..."
dir('the-tip-top-backend') { dir('the-tip-top-backend') {
sh """ sh """
docker build -t ${REGISTRY_URL}/${IMAGE_NAME}:${TAG} . docker build -t ${REGISTRY_URL}/${IMAGE_NAME}:${TAG} .
@ -93,12 +71,9 @@ pipeline {
} }
} }
// ─────────────────────────────── // Stage 5: Push vers le registre privé
// 5⃣ Push vers le registre privé
// ───────────────────────────────
stage('Push to Registry') { stage('Push to Registry') {
steps { steps {
echo "📤 Envoi de limage vers le registre..."
withCredentials([usernamePassword(credentialsId: 'registry-credentials', usernameVariable: 'REG_USER', passwordVariable: 'REG_PASS')]) { withCredentials([usernamePassword(credentialsId: 'registry-credentials', usernameVariable: 'REG_USER', passwordVariable: 'REG_PASS')]) {
sh """ sh """
echo "$REG_PASS" | docker login ${REGISTRY_URL} -u "$REG_USER" --password-stdin echo "$REG_PASS" | docker login ${REGISTRY_URL} -u "$REG_USER" --password-stdin
@ -109,54 +84,20 @@ pipeline {
} }
} }
// ─────────────────────────────── // Stage 6: Déploiement
// 6⃣ Backup avant déploiement
// ───────────────────────────────
stage('Backup Before Deploy') {
steps {
echo "💾 Exécution du script de sauvegarde..."
sh '''
if [ -f /srv/devops/the-tip-top/backup.sh ]; then
bash /srv/devops/the-tip-top/backup.sh
else
echo "⚠️ Aucun script backup.sh trouvé."
fi
'''
}
}
// ───────────────────────────────
// 7⃣ Déploiement
// ───────────────────────────────
stage('Deploy') { stage('Deploy') {
steps { steps {
echo "🚀 Déploiement du backend sur ${env.ENV}..."
sh """ sh """
echo "📂 DEPLOY_PATH utilisé : ${DEPLOY_PATH}"
if [ ! -f "${DEPLOY_PATH}/docker-compose.yml" ]; then
echo "❌ Fichier docker-compose.yml introuvable dans ${DEPLOY_PATH}"
ls -l ${DEPLOY_PATH} || echo "⚠️ Impossible de lister le contenu."
exit 1
fi
cd "${DEPLOY_PATH}" cd "${DEPLOY_PATH}"
echo "📦 Pull de l'image Docker depuis le registre..."
docker compose pull backend docker compose pull backend
echo "🔄 Recréation du conteneur backend..."
docker compose up -d --force-recreate backend docker compose up -d --force-recreate backend
""" """
} }
} }
// ─────────────────────────────── // Stage 7: Health Check
// 8⃣ Vérification de santé (via /health)
// ───────────────────────────────
stage('Health Check') { stage('Health Check') {
steps { steps {
echo "🩺 Vérification du backend après déploiement..."
script { script {
def domain = (env.ENV == 'dev') ? "api.dev.dsp5-archi-o24a-15m-g3.fr" : def domain = (env.ENV == 'dev') ? "api.dev.dsp5-archi-o24a-15m-g3.fr" :
(env.ENV == 'preprod') ? "api.preprod.dsp5-archi-o24a-15m-g3.fr" : (env.ENV == 'preprod') ? "api.preprod.dsp5-archi-o24a-15m-g3.fr" :
@ -166,25 +107,14 @@ pipeline {
for (int i = 1; i <= 10; i++) { for (int i = 1; i <= 10; i++) {
statusCode = sh(script: "curl -k -s -o /dev/null -w '%{http_code}' https://${domain}/health || echo 000", returnStdout: true).trim() statusCode = sh(script: "curl -k -s -o /dev/null -w '%{http_code}' https://${domain}/health || echo 000", returnStdout: true).trim()
if (statusCode in ['200', '301', '302']) { if (statusCode in ['200', '301', '302']) {
echo "✅ Backend ${env.ENV} opérationnel (HTTP ${statusCode})" echo "Backend ${env.ENV} OK (${statusCode})"
return return
} }
echo "⏳ Tentative ${i}/10 → HTTP ${statusCode}"
sleep 5 sleep 5
} }
error("❌ Health check échoué - code HTTP ${statusCode}") error("Health check échoué (${statusCode})")
} }
} }
} }
} }
post {
success {
echo "✅ Pipeline backend ${env.ENV} terminé avec succès !"
}
failure {
echo "❌ Échec du pipeline backend pour ${env.ENV}."
}
}
} }