versioning

This commit is contained in:
2025-12-15 10:35:50 -05:00
parent c23d281832
commit 9742c66fea

40
Jenkinsfile vendored
View File

@@ -3,12 +3,12 @@ pipeline {
environment {
// Tag images with the build number so they are unique
FRONTEND_IMAGE = "chore-app-frontend:${env.BUILD_ID}"
BACKEND_IMAGE = "chore-app-backend:${env.BUILD_ID}"
FRONTEND_IMAGE_LATEST = "chore-app-frontend:latest"
BACKEND_IMAGE_LATEST = "chore-app-backend:latest"
VUE_CONTAINER_NAME = "chore-app-frontend"
FLASK_CONTAINER_NAME = "chore-app-backend"
APP_FRONTEND_NAME = "chore-app-frontend"
APP_BACKEND_NAME = "chore-app-backend"
IMAGE_FRONTEND_NAME = "${APP_FRONTEND_NAME}:${env.BUILD_ID}"
IMAGE_BACKEND_NAME = "${APP_BACKEND_NAME}:${env.BUILD_ID}"
CONTAINER_FRONTEND_NAME = "${APP_FRONTEND_NAME}"
CONTAINER_BACKEND_NAME = "${APP_BACKEND_NAME}"
NETWORK_NAME = "chore-app-net"
}
@@ -35,7 +35,7 @@ pipeline {
stage('Build Frontend (Vue) App') {
steps {
dir('web/vue-app') {
sh 'docker build -t ${FRONTEND_IMAGE} .'
sh 'docker build -t ${IMAGE_FRONTEND_NAME} .'
}
}
}
@@ -43,7 +43,7 @@ pipeline {
stage('Build Backend (Flask) App') {
steps {
dir('.') {
sh """docker build --build-arg APP_BUILD=${BUILD_NUMBER} -t chore-app-backend:${BASE_VERSION}-${BUILD_NUMBER} ."""
sh """docker build --build-arg APP_BUILD=${BUILD_NUMBER} -t ${APP_BACKEND_NAME}:${BASE_VERSION}-${BUILD_NUMBER} ."""
}
}
}
@@ -51,10 +51,10 @@ pipeline {
stage('Deploy') {
steps {
echo 'Stopping and removing old containers...'
sh "docker stop ${VUE_CONTAINER_NAME} || true"
sh "docker rm ${VUE_CONTAINER_NAME} || true"
sh "docker stop ${FLASK_CONTAINER_NAME} || true"
sh "docker rm ${FLASK_CONTAINER_NAME} || true"
sh "docker stop ${CONTAINER_FRONTEND_NAME} || true"
sh "docker rm ${CONTAINER_FRONTEND_NAME} || true"
sh "docker stop ${CONTAINER_BACKEND_NAME} || true"
sh "docker rm ${CONTAINER_BACKEND_NAME} || true"
echo 'Cleaning up and creating network...'
sh "docker network rm -f ${NETWORK_NAME} || true"
@@ -65,19 +65,19 @@ pipeline {
sh """
docker run -d \\
--name ${VUE_CONTAINER_NAME} \\
--name ${CONTAINER_FRONTEND_NAME} \\
--network ${NETWORK_NAME} \\
-p 443:443 \\
${FRONTEND_IMAGE}
${IMAGE_FRONTEND_NAME}
"""
sh """
docker run -d \\
--name ${FLASK_CONTAINER_NAME} \\
--name ${CONTAINER_BACKEND_NAME} \\
--network ${NETWORK_NAME} \\
-e BUILD_NUMBER=${BUILD_NUMBER} \\
-v ${FLASK_CONTAINER_NAME}_data:/app/data \\
chore-app-backend:${BASE_VERSION}-${BUILD_NUMBER}
-v ${CONTAINER_BACKEND_NAME}_data:/app/data \\
${APP_BACKEND_NAME}:${BASE_VERSION}-${BUILD_NUMBER}
"""
echo 'Deployment complete!'
@@ -87,8 +87,8 @@ pipeline {
stage('Tag Latest') {
steps {
echo 'Tagging deployed images as latest...'
sh "docker tag ${FRONTEND_IMAGE} chore-app-frontend:latest"
sh "docker tag chore-app-backend:${BASE_VERSION}-${BUILD_NUMBER} chore-app-backend:latest"
sh "docker tag ${IMAGE_FRONTEND_NAME} chore-app-frontend:latest"
sh "docker tag ${APP_BACKEND_NAME}:${BASE_VERSION}-${BUILD_NUMBER} ${APP_BACKEND_NAME}:latest"
}
}
@@ -107,7 +107,7 @@ pipeline {
echo 'Docker images pruned.'
// Optional: Stop old containers and run the new ones
// Note: In production, you would push to a registry (DockerHub) instead
sh "echo 'Build Complete. Images ready: ${FRONTEND_IMAGE} and ${BACKEND_IMAGE}'"
sh "echo 'Build Complete. Images ready: ${IMAGE_FRONTEND_NAME} and ${IMAGE_BACKEND_NAME}'"
}
}
}