Update new Jenkinsfile

This commit is contained in:
Marija Stopa 2025-01-13 12:41:23 +01:00 committed by GitHub
parent 5c06f69064
commit 42dee8a0f8
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

83
Jenkinsfile vendored
View file

@ -3,15 +3,10 @@ pipeline {
environment { environment {
DOCKER_REPO_MAIN = 'marijastopa/main-jenkins' DOCKER_REPO_MAIN = 'marijastopa/main-jenkins'
DOCKER_REPO_MR = 'marijastopa/mr-jenkins' DOCKER_REPO_MR = 'marijastopa/mr-jenkins'
GIT_COMMIT_SHORT = sh(script: "git rev-parse --short HEAD", returnStdout: true).trim()
DOCKER_IMAGE_MAIN = 'marijastopa/main-jenkins'
DOCKER_IMAGE_MR = 'marijastopa/mr-jenkins'
} }
stages { stages {
stage('Prepare') { stage('Prepare') {
steps { steps {
echo "Branch: ${env.BRANCH_NAME}"
echo "Commit: ${GIT_COMMIT_SHORT}"
echo "Preparing environment..." echo "Preparing environment..."
script { script {
BRANCH_NAME = env.BRANCH_NAME ?: 'main' BRANCH_NAME = env.BRANCH_NAME ?: 'main'
@ -21,99 +16,69 @@ pipeline {
} }
} }
} }
// Jobs for Merge Requests
// Merge Request Pipeline Stages
stage('Checkstyle') { stage('Checkstyle') {
when { when {
expression { expression { BRANCH_NAME != 'main' }
return env.BRANCH_NAME != 'main'
BRANCH_NAME != 'main'
}
} }
steps { steps {
echo "Running Checkstyle..." echo "Running Checkstyle..."
sh './gradlew checkstyleMain checkstyleTest' sh './gradlew checkstyleMain checkstyleTest'
archiveArtifacts artifacts: '**/build/reports/checkstyle/*.xml', allowEmptyArchive: true archiveArtifacts artifacts: '**/build/reports/checkstyle/*.xml', allowEmptyArchive: true
echo "Checkstyle completed and reports archived"
} }
} }
stage('Test') { stage('Test') {
when { when {
expression { expression { BRANCH_NAME != 'main' }
return env.BRANCH_NAME != 'main'
BRANCH_NAME != 'main'
}
} }
steps { steps {
echo "Running Tests..." echo "Running Tests..."
echo "Running tests..."
sh './gradlew test' sh './gradlew test'
junit '**/build/test-results/test/*.xml' junit '**/build/test-results/test/*.xml'
} }
} }
stage('Build without Tests') { stage('Build without Tests') {
when { when {
expression { expression { BRANCH_NAME != 'main' }
return env.BRANCH_NAME != 'main'
BRANCH_NAME != 'main'
}
} }
steps { steps {
echo "Building without running tests..." echo "Building application without tests..."
echo "Building application (without tests)..."
sh './gradlew clean build -x test' sh './gradlew clean build -x test'
} }
} }
stage('Docker Build & Push (Merge Request)') { stage('Docker Build & Push (Merge Request)') {
when { when {
expression { expression { BRANCH_NAME != 'main' }
return env.BRANCH_NAME != 'main'
BRANCH_NAME != 'main'
}
} }
steps { steps {
echo "Building Docker image for MR..."
sh "docker build -t ${DOCKER_REPO_MR}:${GIT_COMMIT_SHORT} ."
withCredentials([string(credentialsId: 'dockerhub-credentials', variable: 'DOCKER_PASS')]) {
sh '''
echo $DOCKER_PASS | docker login -u marijastopa --password-stdin
docker push ${DOCKER_REPO_MR}:${GIT_COMMIT_SHORT}
docker tag ${DOCKER_REPO_MR}:${GIT_COMMIT_SHORT} ${DOCKER_REPO_MR}:latest
docker push ${DOCKER_REPO_MR}:latest
'''
echo "Building Docker image for merge request..." echo "Building Docker image for merge request..."
withCredentials([usernamePassword(credentialsId: 'dockerhub-credentials', usernameVariable: 'DOCKER_USER', passwordVariable: 'DOCKER_PASS')]) { withCredentials([usernamePassword(credentialsId: 'dockerhub-credentials', usernameVariable: 'DOCKER_USER', passwordVariable: 'DOCKER_PASS')]) {
sh """ sh """
docker build -t $DOCKER_IMAGE_MR:${COMMIT} . docker build -t ${DOCKER_REPO_MR}:${COMMIT} .
echo "$DOCKER_PASS" | docker login -u "$DOCKER_USER" --password-stdin echo "$DOCKER_PASS" | docker login -u "$DOCKER_USER" --password-stdin
docker push $DOCKER_IMAGE_MR:${COMMIT} docker push ${DOCKER_REPO_MR}:${COMMIT}
docker tag $DOCKER_IMAGE_MR:${COMMIT} $DOCKER_IMAGE_MR:latest docker tag ${DOCKER_REPO_MR}:${COMMIT} ${DOCKER_REPO_MR}:latest
docker push $DOCKER_IMAGE_MR:latest docker push ${DOCKER_REPO_MR}:latest
""" """
} }
} }
} }
// Jobs for Main Branch
// Main Branch Pipeline Stage
stage('Docker Build & Push (Main Branch)') { stage('Docker Build & Push (Main Branch)') {
when { when {
branch 'main' branch 'main'
} }
steps { steps {
echo "Building Docker image for main branch..." echo "Building Docker image for main branch..."
sh "docker build -t ${DOCKER_REPO_MAIN}:${GIT_COMMIT_SHORT} ."
withCredentials([string(credentialsId: 'dockerhub-credentials', variable: 'DOCKER_PASS')]) {
sh '''
echo $DOCKER_PASS | docker login -u marijastopa --password-stdin
docker push ${DOCKER_REPO_MAIN}:${GIT_COMMIT_SHORT}
docker tag ${DOCKER_REPO_MAIN}:${GIT_COMMIT_SHORT} ${DOCKER_REPO_MAIN}:latest
docker push ${DOCKER_REPO_MAIN}:latest
'''
withCredentials([usernamePassword(credentialsId: 'dockerhub-credentials', usernameVariable: 'DOCKER_USER', passwordVariable: 'DOCKER_PASS')]) { withCredentials([usernamePassword(credentialsId: 'dockerhub-credentials', usernameVariable: 'DOCKER_USER', passwordVariable: 'DOCKER_PASS')]) {
sh """ sh """
docker build -t $DOCKER_IMAGE_MAIN:${COMMIT} . docker build -t ${DOCKER_REPO_MAIN}:${COMMIT} .
echo "$DOCKER_PASS" | docker login -u "$DOCKER_USER" --password-stdin echo "$DOCKER_PASS" | docker login -u "$DOCKER_USER" --password-stdin
docker push $DOCKER_IMAGE_MAIN:${COMMIT} docker push ${DOCKER_REPO_MAIN}:${COMMIT}
docker tag $DOCKER_IMAGE_MAIN:${COMMIT} $DOCKER_IMAGE_MAIN:latest docker tag ${DOCKER_REPO_MAIN}:${COMMIT} ${DOCKER_REPO_MAIN}:latest
docker push $DOCKER_IMAGE_MAIN:latest docker push ${DOCKER_REPO_MAIN}:latest
""" """
} }
} }
@ -122,22 +87,16 @@ pipeline {
post { post {
always { always {
echo "Cleaning up Docker images..." echo "Cleaning up Docker images..."
sh 'docker rmi $(docker images -f "dangling=true" -q) || true' sh """
docker ps -a -q | xargs --no-run-if-empty docker rm -f || true
docker images -f dangling=true -q | xargs --no-run-if-empty docker rmi -f || true
"""
} }
success { success {
echo "Pipeline completed successfully!" echo "Pipeline completed successfully!"
sh """
docker ps -a -q | xargs docker rm -f || true
docker images -f dangling=true -q | xargs docker rmi -f || true
"""
} }
failure { failure {
echo "Pipeline failed. Check logs for errors." echo "Pipeline failed. Check logs for errors."
echo 'Pipeline failed. Check logs for errors.'
}
success {
echo 'Pipeline executed successfully!'
} }
} }
} }
}