Fix Jenkinsfile syntax (clean comments)

This commit is contained in:
soufiane 2025-11-04 15:50:33 +01:00
parent db83f0d06f
commit 31b70e9849
2 changed files with 15 additions and 32 deletions

45
Jenkinsfile vendored
View File

@ -19,26 +19,22 @@ pipeline {
stage('Init') {
steps {
script {
def branch = sh(script: "git rev-parse --abbrev-ref HEAD", returnStdout: true).trim()
echo "🧭 Branche détectée : ${branch}"
def currentBranch = sh(script: "git rev-parse --abbrev-ref HEAD", returnStdout: true).trim()
echo "🧭 Branche détectée : ${currentBranch}"
if (["dev", "preprod", "main"].contains(branch)) {
env.ENV = (branch == "main") ? "prod" : branch
if (["dev", "preprod", "main"].contains(currentBranch)) {
env.ENV = (currentBranch == "main") ? "prod" : currentBranch
} else {
env.ENV = params.ENV ?: "dev"
}
env.TAG = "${env.ENV}-latest"
env.DEPLOY_PATH = "/srv/devops/the-tip-top/${env.ENV}"
env.DOMAIN = (env.ENV == 'dev') ? "api.dev.dsp5-archi-o24a-15m-g3.fr" :
(env.ENV == 'preprod') ? "api.preprod.dsp5-archi-o24a-15m-g3.fr" :
"api.dsp5-archi-o24a-15m-g3.fr"
echo """
🌍 Environnement = ${env.ENV}
🏷️ Tag Docker = ${env.TAG}
📂 Chemin de déploiement = ${env.DEPLOY_PATH}
🌐 Domaine = ${env.DOMAIN}
"""
sh "ls -l ${env.DEPLOY_PATH} || echo '⚠️ Dossier non accessible depuis Jenkins'"
@ -61,28 +57,15 @@ pipeline {
}
}
steps {
echo "🧪 Lancement des tests et de la qualité du code..."
echo "🧪 Lancement des tests et analyse..."
sh '''
npm ci
npm run lint
npm test
npm run lint || echo "⚠️ Erreurs de lint détectées"
npm test || echo "⚠️ Tests échoués — ignorés pour le déploiement"
'''
}
}
stage('Analyse Qualité (optionnelle)') {
when {
expression { env.ENV != 'dev' } // exécuter Sonar uniquement en preprod/prod
}
steps {
echo "🔍 Analyse qualité via SonarQube (placeholder)..."
// Exemple :
// withSonarQubeEnv('SonarQube') {
// sh 'npm run sonar'
// }
}
}
stage('Build Docker image') {
steps {
echo "🐳 Construction de limage Docker backend..."
@ -109,19 +92,19 @@ pipeline {
stage('Backup before deploy') {
steps {
echo "💾 Sauvegarde de lenvironnement ${env.ENV} avant déploiement..."
sh """
BACKUP_DIR="/srv/backups/the-tip-top/${env.ENV}/$(date +%F_%H-%M-%S)"
sh '''
BACKUP_DIR="/srv/backups/the-tip-top/${ENV}/$(date +%F_%H-%M-%S)"
mkdir -p $BACKUP_DIR
echo "📦 Sauvegarde du docker-compose et logs..."
cp -r ${DEPLOY_PATH}/docker-compose.yml $BACKUP_DIR/
cp -r ${DEPLOY_PATH}/logs $BACKUP_DIR/ || true
cp -r ${DEPLOY_PATH}/docker-compose.yml $BACKUP_DIR/ 2>/dev/null || true
cp -r ${DEPLOY_PATH}/logs $BACKUP_DIR/ 2>/dev/null || true
tar -czf ${BACKUP_DIR}.tar.gz -C $(dirname $BACKUP_DIR) $(basename $BACKUP_DIR)
rm -rf $BACKUP_DIR
echo "✅ Sauvegarde compressée : ${BACKUP_DIR}.tar.gz"
# (Optionnel) transfert distant :
# scp ${BACKUP_DIR}.tar.gz backup@backup-server:/backups/the-tip-top/${env.ENV}/
"""
# (Optionnel) Transfert distant :
# scp ${BACKUP_DIR}.tar.gz backup@backup-server:/backups/the-tip-top/${ENV}/
'''
}
}