Fix Jenkinsfile syntax (clean comments)

This commit is contained in:
soufiane 2025-11-04 15:29:35 +01:00
parent 5cedb52e4c
commit 77ed26c527
2 changed files with 24 additions and 71 deletions

View File

@ -1,22 +1,16 @@
# Utilise une image Node légère
FROM node:18-alpine FROM node:18-alpine
WORKDIR /app WORKDIR /app
# Copie les fichiers
COPY package*.json ./ COPY package*.json ./
RUN npm ci --omit=dev RUN npm install --omit=dev
COPY . . COPY . .
# Nettoyer le .env pour ne pas écraser les variables Docker (facultatif mais recommandé) # Définit la variable denvironnement
# RUN rm -f .env ENV NODE_ENV=production
# Installer curl pour le healthcheck
RUN apk add --no-cache curl
EXPOSE 4000 EXPOSE 4000
# Healthcheck plus robuste
HEALTHCHECK --interval=30s --timeout=10s --start-period=15s --retries=3 \
CMD curl -f http://localhost:4000/health || exit 1
CMD ["npm", "start"] CMD ["npm", "start"]

79
Jenkinsfile vendored
View File

@ -5,7 +5,7 @@ pipeline {
choice( choice(
name: 'ENV', name: 'ENV',
choices: ['dev', 'preprod', 'prod'], choices: ['dev', 'preprod', 'prod'],
description: 'Choisir lenvironnement de déploiement (automatique si branche correspondante)' description: 'Choisir lenvironnement de déploiement'
) )
} }
@ -16,14 +16,11 @@ pipeline {
stages { stages {
/* ───────────────────────────────
* 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
@ -40,25 +37,18 @@ pipeline {
📂 Chemin de déploiement = ${env.DEPLOY_PATH} 📂 Chemin de déploiement = ${env.DEPLOY_PATH}
""" """
// Vérifie le répertoire cible
sh "ls -l ${env.DEPLOY_PATH} || echo '⚠️ Dossier non accessible depuis Jenkins'" sh "ls -l ${env.DEPLOY_PATH} || echo '⚠️ Dossier non accessible depuis Jenkins'"
} }
} }
} }
/* ───────────────────────────────
* 2⃣ Checkout du code
* ─────────────────────────────── */
stage('Checkout') { stage('Checkout') {
steps { steps {
echo "📦 Récupération du code source depuis Gitea..." echo "📦 Récupération du code source..."
checkout scm checkout scm
} }
} }
/* ───────────────────────────────
* 3⃣ Tests & Qualité (dans un conteneur Node.js)
* ─────────────────────────────── */
stage('Tests & Qualité') { stage('Tests & Qualité') {
agent { agent {
docker { docker {
@ -67,35 +57,28 @@ pipeline {
} }
} }
steps { steps {
echo "🧪 Lancement des tests et analyse de code..." echo "🧪 Lancement des tests et analyse..."
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 — ignorés pour le déploiement"
''' '''
} }
} }
/* ───────────────────────────────
* 4⃣ Build de limage Docker
* ─────────────────────────────── */
stage('Build Docker image') { stage('Build Docker image') {
steps { steps {
dir('the-tip-top-backend') { echo "🐳 Construction de limage Docker backend..."
sh """ sh """
docker build -t ${REGISTRY_URL}/${IMAGE_NAME}:${TAG} . docker build -t ${REGISTRY_URL}/${IMAGE_NAME}:${TAG} .
docker tag ${REGISTRY_URL}/${IMAGE_NAME}:${TAG} ${REGISTRY_URL}/${IMAGE_NAME}:latest docker tag ${REGISTRY_URL}/${IMAGE_NAME}:${TAG} ${REGISTRY_URL}/${IMAGE_NAME}:latest
""" """
}
} }
} }
/* ───────────────────────────────
* 5⃣ Push vers le registre privé
* ─────────────────────────────── */
stage('Push to Registry') { stage('Push to Registry') {
steps { steps {
echo "📤 Envoi de limage vers le registre Docker privé..." 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
@ -106,28 +89,9 @@ pipeline {
} }
} }
/* ───────────────────────────────
* 6⃣ Backup avant déploiement
* ─────────────────────────────── */
stage('Backup Before Deploy') {
steps {
echo "💾 Exécution du script de sauvegarde avant déploiement..."
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}..." echo "🚀 Déploiement sur ${env.ENV}..."
sh """ sh """
cd "${DEPLOY_PATH}" cd "${DEPLOY_PATH}"
docker compose pull backend docker compose pull backend
@ -136,13 +100,9 @@ pipeline {
} }
} }
/* ───────────────────────────────
* 8⃣ Vérification de santé (via /health)
* ─────────────────────────────── */
* ─────────────────────────────── */
stage('Health Check') { stage('Health Check') {
steps { steps {
echo "🩺 Vérification du backend après déploiement..." echo "🩺 Vérification de létat du backend..."
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" :
@ -152,26 +112,25 @@ 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} OK (${statusCode})" echo "✅ Backend ${env.ENV} opérationnel (HTTP ${statusCode})"
return return
} }
echo "⏳ Tentative ${i}/10 → HTTP ${statusCode}"
sleep 5 sleep 5
} }
error("Health check échoué (${statusCode})") error("❌ Health check échoué - code HTTP ${statusCode}")
} }
} }
} }
} }
/* ───────────────────────────────
* 🔚 Post Actions
* ─────────────────────────────── */
post { post {
success { success {
echo "✅ Pipeline backend ${env.ENV} terminé avec succès !" echo "✅ Pipeline ${env.ENV} terminé avec succès !"
} }
failure { failure {
echo "❌ Échec du pipeline backend pour ${env.ENV}." echo "❌ Échec du pipeline ${env.ENV}."
} }
} }
} }