Fix Jenkinsfile syntax (clean comments)

This commit is contained in:
soufiane 2025-11-04 15:28:17 +01:00
parent 3ddf94cce2
commit bb0aa2fa44
3 changed files with 32 additions and 69 deletions

78
Jenkinsfile vendored
View File

@ -1,17 +1,11 @@
pipeline { pipeline {
agent any agent any
// 🔁 Vérifie toutes les 2 minutes si du nouveau code a été poussé
triggers {
pollSCM('* * * *')
}
// ⚙️ Paramètre manuel (fallback)
parameters { parameters {
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'
) )
} }
@ -22,9 +16,6 @@ pipeline {
stages { stages {
/* ───────────────────────────────
* 1⃣ Init — Détection automatique de lenvironnement
* ─────────────────────────────── */
stage('Init') { stage('Init') {
steps { steps {
script { script {
@ -46,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 {
@ -73,18 +57,15 @@ 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 {
echo "🐳 Construction de limage Docker backend..." echo "🐳 Construction de limage Docker backend..."
@ -95,12 +76,9 @@ pipeline {
} }
} }
/* ───────────────────────────────
* 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
@ -111,55 +89,20 @@ 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 """
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
""" """
} }
} }
/* ───────────────────────────────
* 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" :
@ -182,15 +125,12 @@ pipeline {
} }
} }
/* ───────────────────────────────
* 🔚 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}."
} }
} }
} }

17
eslint.config.js Normal file
View File

@ -0,0 +1,17 @@
// eslint.config.js
export default [
{
files: ["**/*.js"],
ignores: ["node_modules/**"],
languageOptions: {
sourceType: "module",
ecmaVersion: "latest",
},
rules: {
semi: ["error", "always"],
quotes: ["error", "double"],
"no-unused-vars": ["warn"],
"no-console": "off",
},
},
];

6
jest.config.js Normal file
View File

@ -0,0 +1,6 @@
// jest.config.js
export default {
testEnvironment: "node",
transform: {}, // pas de transpilation Babel ici
verbose: true,
};