Files
it_school/project2/jenkinsfile
Ionel Andrei Cataon e2fce3a281 p2
2026-02-12 17:01:19 +02:00

65 lines
2.5 KiB
Plaintext

pipeline {
agent any
stages {
stage('Build & Lint') {
steps {
script {
dir('project2') {
sh "docker build -t quotes-app ."
echo "🔍 Verificăm sintaxa codului..."
sh "docker run --rm quotes-app python -m py_compile famousquotes.py"
}
}
}
}
stage('Run & Extract') {
steps {
script {
dir('project2') {
// Curățăm preventiv containerul dacă a rămas blocat de la un build anterior
sh "docker rm -f quotes-worker || true"
try {
sh "docker run --name quotes-worker --dns 8.8.8.8 quotes-app"
sh "docker cp quotes-worker:/app/quote.txt ."
} catch (e) {
echo "⚠️ Eroare la rulare, dar încercăm notificarea."
} finally {
sh "docker rm -f quotes-worker || true"
}
}
}
}
}
}
post {
always {
script {
def discordUrl = "https://discord.com/api/webhooks/1471492658336891013/T5s6ZKZjJjDMHXc3k3jjZdk6m5EV12bKF1wda9d5I_gZJrsDZQ1m1m078IiLJWK38mqa"
def quoteText = "Nu am putut citi fișierul."
if (fileExists('project2/quote.txt')) {
quoteText = readFile('project2/quote.txt').trim()
}
def resultStatus = currentBuild.result ?: 'SUCCESS'
def statusEmoji = (resultStatus == 'SUCCESS') ? "✅" : "⚠️"
echo "🚀 Trimitere notificare către Discord..."
// Creăm un fișier JSON temporar pentru a evita problemele de shell
def payload = [
content: "${statusEmoji} **Pipeline Finalizat (Build #${env.BUILD_NUMBER})**\n\n${quoteText}"
]
// Scriem payload-ul într-un fișier discord_payload.json
writeJSON file: 'discord_payload.json', json: payload
// Trimitem fișierul folosind @ la curl - asta e metoda cea mai sigură!
sh "curl -X POST -H 'Content-Type: application/json' -d @discord_payload.json '${discordUrl}'"
}
}
}
}