update: jenkinsfile code for multibranch pipeline
This commit is contained in:
parent
e725c3610f
commit
6863825e97
|
|
@ -7,7 +7,6 @@ pipeline {
|
||||||
MANIFEST_REPO = "https://git.winteraccess.id/adel/Employee-manifest.git"
|
MANIFEST_REPO = "https://git.winteraccess.id/adel/Employee-manifest.git"
|
||||||
MANIFEST_CRED_ID = "GIT_CRED_ID"
|
MANIFEST_CRED_ID = "GIT_CRED_ID"
|
||||||
DOCKER_CRED_ID = "DOCKER_CRED_ID"
|
DOCKER_CRED_ID = "DOCKER_CRED_ID"
|
||||||
BRANCHES = "dev stag prod"
|
|
||||||
MANIFEST_DIR = "manifest"
|
MANIFEST_DIR = "manifest"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -16,7 +15,6 @@ pipeline {
|
||||||
}
|
}
|
||||||
|
|
||||||
stages {
|
stages {
|
||||||
|
|
||||||
stage('Prepare Workspace') {
|
stage('Prepare Workspace') {
|
||||||
steps {
|
steps {
|
||||||
cleanWs()
|
cleanWs()
|
||||||
|
|
@ -47,11 +45,9 @@ pipeline {
|
||||||
sh """
|
sh """
|
||||||
echo "\$DOCKER_PASS" | docker login -u "\$DOCKER_USER" --password-stdin
|
echo "\$DOCKER_PASS" | docker login -u "\$DOCKER_USER" --password-stdin
|
||||||
|
|
||||||
# Build & push backend
|
|
||||||
docker build -t ${REGISTRY}/${APP_NAME}-be:${tag} ./employee-be
|
docker build -t ${REGISTRY}/${APP_NAME}-be:${tag} ./employee-be
|
||||||
docker push ${REGISTRY}/${APP_NAME}-be:${tag}
|
docker push ${REGISTRY}/${APP_NAME}-be:${tag}
|
||||||
|
|
||||||
# Build & push frontend
|
|
||||||
docker build -t ${REGISTRY}/${APP_NAME}-fe:${tag} ./employee-fe
|
docker build -t ${REGISTRY}/${APP_NAME}-fe:${tag} ./employee-fe
|
||||||
docker push ${REGISTRY}/${APP_NAME}-fe:${tag}
|
docker push ${REGISTRY}/${APP_NAME}-fe:${tag}
|
||||||
|
|
||||||
|
|
@ -64,38 +60,48 @@ pipeline {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
stage('Update Manifests for All Environments') {
|
stage('Update Manifest for Current Branch') {
|
||||||
steps {
|
steps {
|
||||||
script {
|
script {
|
||||||
withCredentials([usernamePassword(credentialsId: env.MANIFEST_CRED_ID, usernameVariable: 'GIT_USER', passwordVariable: 'GIT_PASS')]) {
|
def currentBranch = env.BRANCH_NAME ?: sh(script: "git rev-parse --abbrev-ref HEAD", returnStdout: true).trim()
|
||||||
|
echo "Current branch detected: ${currentBranch}"
|
||||||
|
|
||||||
// Clone manifest repo pakai credential
|
def envMap = [
|
||||||
|
"develop": "dev",
|
||||||
|
"staging": "stag",
|
||||||
|
"main": "prod"
|
||||||
|
]
|
||||||
|
def overlayEnv = envMap.get(currentBranch, currentBranch)
|
||||||
|
|
||||||
|
if (!["dev", "stag", "prod"].contains(overlayEnv)) {
|
||||||
|
error "Invalid branch/environment: ${overlayEnv}. Only dev, stag, or prod allowed."
|
||||||
|
}
|
||||||
|
|
||||||
|
withCredentials([usernamePassword(credentialsId: env.MANIFEST_CRED_ID, usernameVariable: 'GIT_USER', passwordVariable: 'GIT_PASS')]) {
|
||||||
sh """
|
sh """
|
||||||
|
echo "Cloning manifest repo..."
|
||||||
rm -rf ${MANIFEST_DIR}
|
rm -rf ${MANIFEST_DIR}
|
||||||
git clone https://\$GIT_USER:\$GIT_PASS@${env.MANIFEST_REPO.replace('https://', '')} ${MANIFEST_DIR}
|
git clone https://\$GIT_USER:\$GIT_PASS@${env.MANIFEST_REPO.replace('https://', '')} ${MANIFEST_DIR}
|
||||||
"""
|
"""
|
||||||
|
|
||||||
dir(env.MANIFEST_DIR) {
|
dir(env.MANIFEST_DIR) {
|
||||||
env.BRANCHES.split().each { envName ->
|
|
||||||
echo "🔹 Updating manifests for environment: ${envName}"
|
|
||||||
|
|
||||||
sh """
|
sh """
|
||||||
git checkout ${envName} || git checkout -b ${envName}
|
git checkout ${overlayEnv} || git checkout -b ${overlayEnv}
|
||||||
|
|
||||||
# Update backend & frontend image tags di overlay sesuai environment
|
echo "Updating image tags inside overlays/${overlayEnv}/patch-deployment.yaml..."
|
||||||
yq e -i '.spec.template.spec.containers[0].image = "${REGISTRY}/${APP_NAME}-be:${envName}-${env.IMAGE_TAG_FINAL}"' overlays/${envName}/patch-deployment.yaml
|
yq e -i '(.spec.template.spec.containers[] | select(.name == "backend") | .image) = "${REGISTRY}/${APP_NAME}-be:${overlayEnv}-${env.IMAGE_TAG_FINAL}"' overlays/${overlayEnv}/patch-deployment.yaml
|
||||||
yq e -i '.spec.template.spec.containers[0].image = "${REGISTRY}/${APP_NAME}-fe:${envName}-${env.IMAGE_TAG_FINAL}"' overlays/${envName}/patch-deployment.yaml
|
yq e -i '(.spec.template.spec.containers[] | select(.name == "frontend") | .image) = "${REGISTRY}/${APP_NAME}-fe:${overlayEnv}-${env.IMAGE_TAG_FINAL}"' overlays/${overlayEnv}/patch-deployment.yaml
|
||||||
|
|
||||||
git add overlays/${envName}/patch-deployment.yaml overlays/${envName}/patch-deployment.yaml
|
git add overlays/${overlayEnv}/patch-deployment.yaml
|
||||||
git commit -m "chore(${envName}): update image tags to ${envName}-${env.IMAGE_TAG_FINAL}" || echo "No changes for ${envName}"
|
git commit -m "chore(${overlayEnv}): update image tags to ${overlayEnv}-${env.IMAGE_TAG_FINAL}" || echo "No changes to commit"
|
||||||
git push https://\$GIT_USER:\$GIT_PASS@${env.MANIFEST_REPO.replace('https://', '')} ${envName}
|
|
||||||
|
git push https://\$GIT_USER:\$GIT_PASS@${env.MANIFEST_REPO.replace('https://', '')} ${overlayEnv}
|
||||||
"""
|
"""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
stage('ArgoCD Sync (optional)') {
|
stage('ArgoCD Sync (optional)') {
|
||||||
steps {
|
steps {
|
||||||
|
|
@ -106,10 +112,10 @@ pipeline {
|
||||||
|
|
||||||
post {
|
post {
|
||||||
success {
|
success {
|
||||||
echo "✅ GitOps pipeline completed successfully for dev, stag, and prod!"
|
echo "Pipeline completed successfully for branch: ${env.BRANCH_NAME}"
|
||||||
}
|
}
|
||||||
failure {
|
failure {
|
||||||
echo "❌ Pipeline failed. Check logs for details."
|
echo "Pipeline failed. Check logs for details."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue