From 043e60906a91be829f244c137d2824e5c445632c Mon Sep 17 00:00:00 2001 From: Ionel Andrei Cataon Date: Thu, 12 Feb 2026 17:23:11 +0200 Subject: [PATCH] p2 --- project2/jenkinsfile | 57 ++++++++++++++++++++++++++++++++++---------- 1 file changed, 45 insertions(+), 12 deletions(-) diff --git a/project2/jenkinsfile b/project2/jenkinsfile index 9b38945..f6fec50 100644 --- a/project2/jenkinsfile +++ b/project2/jenkinsfile @@ -1,7 +1,7 @@ pipeline { agent any - - // Această secțiune spune Jenkins-ului să ruleze build-ul la fiecare 5 minute + + // Programarea automată a rulării la fiecare 5 minute triggers { cron('*/5 * * * *') } @@ -11,40 +11,73 @@ pipeline { steps { script { dir('project2') { + // --no-cache asigură că Docker preia mereu ultima variantă a codului Python sh "docker build --no-cache -t quotes-app ." } } } } - stage('Run') { + + stage('Run & Extract') { steps { script { dir('project2') { + // Curățăm preventiv containerul anterior sh "docker rm -f quotes-worker || true" - // Rulăm cu DNS setat pentru a evita erorile de rețea anterioare - sh "docker run --name quotes-worker --dns 8.8.8.8 quotes-app" - sh "docker cp quotes-worker:/app/quote.txt . " + + try { + // Rulăm containerul cu DNS setat pentru a evita erorile de Name Resolution + sh "docker run --name quotes-worker --dns 8.8.8.8 quotes-app" + + // Copiem fișierul generat din container în workspace-ul Jenkins + sh "docker cp quotes-worker:/app/quote.txt ." + } catch (e) { + echo "⚠️ Eroare la execuție, dar verificăm fișierul pentru notificare." + } finally { + sh "docker rm -f quotes-worker || true" + } } } } } } + post { always { script { def discordUrl = "https://discord.com/api/webhooks/1471492658336891013/T5s6ZKZjJjDMHXc3k3jjZdk6m5EV12bKF1wda9d5I_gZJrsDZQ1m1m078IiLJWK38mqa" - def quote = fileExists('project2/quote.txt') ? readFile('project2/quote.txt').trim() : "Nu am putut genera citatul." - - def safeQuote = quote.replace('\\', '\\\\').replace('"', '\\"').replace('\n', '\\n') + // Citirea citatului și gestionarea erorilor de fișier + def quoteContent = "Nu am putut citi citatul." + if (fileExists('project2/quote.txt')) { + quoteContent = readFile('project2/quote.txt').trim() + // Escapăm caracterele speciale pentru a nu strica formatul JSON + quoteContent = quoteContent.replace('\\', '\\\\').replace('"', '\\"').replace('\n', '\\n') + } + + def resultStatus = currentBuild.result ?: 'SUCCESS' + def statusEmoji = (resultStatus == 'SUCCESS') ? "✅" : "⚠️" + def header = "${statusEmoji} **Pipeline Automat (Build #${env.BUILD_NUMBER})**" + + echo "🚀 Trimitere notificare către Discord..." + + // Crearea payload-ului JSON manual (fără a depinde de plugin-ul writeJSON) sh """ - cat << 'EOF' > payload.json + cat << 'EOF' > discord_payload.json { - "content": "✅ **Pipeline Automat (Build #${env.BUILD_NUMBER})**\\n\\n${safeQuote}" + "content": "${header}\\n\\n${quoteContent}" } EOF """ - sh "curl -X POST -H 'Content-Type: application/json' --data-binary @payload.json '${discordUrl}'" + + // Trimiterea către Discord folosind curl + sh "curl -X POST -H 'Content-Type: application/json' --data-binary @discord_payload.json '${discordUrl}'" + + // CURĂȚARE: Ștergem imaginile Docker inutile (dangling images) pentru a nu umple discul + sh "docker image prune -f" + + // Curățăm workspace-ul curent + deleteDir() } } }