fix(pipeline): Exit full pipeline on a single error
This commit is contained in:
150
pipeline.sh
150
pipeline.sh
@@ -111,28 +111,41 @@ validate_environment() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
frontend_job() {
|
frontend_job() {
|
||||||
local exit_code=0
|
|
||||||
local log_file="$TEMP_DIR/frontend.log"
|
local log_file="$TEMP_DIR/frontend.log"
|
||||||
local use_prefix=$1
|
local use_prefix=$1
|
||||||
|
|
||||||
{
|
(
|
||||||
|
set +e
|
||||||
|
|
||||||
echo "==================== FRONTEND JOB ===================="
|
echo "==================== FRONTEND JOB ===================="
|
||||||
log_info "Starting frontend build..."
|
log_info "Starting frontend build..."
|
||||||
|
|
||||||
cd "$SCRIPT_DIR/legalconsenthub"
|
cd "$SCRIPT_DIR/legalconsenthub" || exit 1
|
||||||
|
|
||||||
log_info "Installing dependencies..."
|
log_info "Installing dependencies..."
|
||||||
pnpm install --frozen-lockfile
|
pnpm install --frozen-lockfile
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
log_error "Dependencies installation failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
log_success "Dependencies installed"
|
log_success "Dependencies installed"
|
||||||
|
|
||||||
log_info "Running linting..."
|
log_info "Running linting..."
|
||||||
pnpm lint
|
pnpm lint
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
log_error "Linting failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
log_success "Linting passed"
|
log_success "Linting passed"
|
||||||
|
|
||||||
log_info "Running type checking..."
|
log_info "Running type checking..."
|
||||||
pnpm type-check
|
pnpm type-check
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
log_error "Type checking failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
log_success "Type checking passed"
|
log_success "Type checking passed"
|
||||||
|
|
||||||
log_info "Building Docker image..."
|
log_info "Building Docker image..."
|
||||||
docker buildx build \
|
docker buildx build \
|
||||||
--platform linux/amd64 \
|
--platform linux/amd64 \
|
||||||
@@ -141,42 +154,57 @@ frontend_job() {
|
|||||||
--file ./Dockerfile \
|
--file ./Dockerfile \
|
||||||
--push \
|
--push \
|
||||||
..
|
..
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
log_error "Docker build failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
log_success "Docker image built and pushed successfully"
|
log_success "Docker image built and pushed successfully"
|
||||||
log_info "Image: gitea.lugnas.de/denis/legalconsenthub:latest"
|
log_info "Image: gitea.lugnas.de/denis/legalconsenthub:latest"
|
||||||
log_info "Image: gitea.lugnas.de/denis/legalconsenthub:$GIT_SHA"
|
log_info "Image: gitea.lugnas.de/denis/legalconsenthub:$GIT_SHA"
|
||||||
|
|
||||||
echo "0" > "$TEMP_DIR/frontend_exit_code"
|
exit 0
|
||||||
} 2>&1 | if [ "$use_prefix" = true ]; then prefix_output "FRONTEND" "$BLUE"; else cat; fi | tee "$log_file" || {
|
) 2>&1 | if [ "$use_prefix" = true ]; then prefix_output "FRONTEND" "$BLUE"; else cat; fi | tee "$log_file"
|
||||||
exit_code=$?
|
|
||||||
log_error "Frontend job failed with exit code $exit_code"
|
return ${PIPESTATUS[0]}
|
||||||
echo "$exit_code" > "$TEMP_DIR/frontend_exit_code"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
backend_job() {
|
backend_job() {
|
||||||
local exit_code=0
|
|
||||||
local log_file="$TEMP_DIR/backend.log"
|
local log_file="$TEMP_DIR/backend.log"
|
||||||
local use_prefix=$1
|
local use_prefix=$1
|
||||||
|
|
||||||
{
|
(
|
||||||
|
set +e
|
||||||
|
|
||||||
echo "==================== BACKEND JOB ===================="
|
echo "==================== BACKEND JOB ===================="
|
||||||
log_info "Starting backend build..."
|
log_info "Starting backend build..."
|
||||||
|
|
||||||
cd "$SCRIPT_DIR/legalconsenthub-backend"
|
cd "$SCRIPT_DIR/legalconsenthub-backend" || exit 1
|
||||||
|
|
||||||
log_info "Building application..."
|
log_info "Building application..."
|
||||||
./gradlew build -x test
|
./gradlew build -x test
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
log_error "Build failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
log_success "Build completed"
|
log_success "Build completed"
|
||||||
|
|
||||||
log_info "Running ktlint check..."
|
log_info "Running ktlint check..."
|
||||||
./gradlew ktlintCheck
|
./gradlew ktlintCheck
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
log_error "ktlint check failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
log_success "ktlint check passed"
|
log_success "ktlint check passed"
|
||||||
|
|
||||||
log_info "Running tests..."
|
log_info "Running tests..."
|
||||||
./gradlew test
|
./gradlew test
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
log_error "Tests failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
log_success "Tests passed"
|
log_success "Tests passed"
|
||||||
|
|
||||||
log_info "Building Docker image..."
|
log_info "Building Docker image..."
|
||||||
docker buildx build \
|
docker buildx build \
|
||||||
--platform linux/amd64 \
|
--platform linux/amd64 \
|
||||||
@@ -185,22 +213,24 @@ backend_job() {
|
|||||||
--file ./Dockerfile \
|
--file ./Dockerfile \
|
||||||
--push \
|
--push \
|
||||||
..
|
..
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
log_error "Docker build failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
log_success "Docker image built and pushed successfully"
|
log_success "Docker image built and pushed successfully"
|
||||||
log_info "Image: gitea.lugnas.de/denis/legalconsenthub-backend:latest"
|
log_info "Image: gitea.lugnas.de/denis/legalconsenthub-backend:latest"
|
||||||
log_info "Image: gitea.lugnas.de/denis/legalconsenthub-backend:$GIT_SHA"
|
log_info "Image: gitea.lugnas.de/denis/legalconsenthub-backend:$GIT_SHA"
|
||||||
|
|
||||||
echo "0" > "$TEMP_DIR/backend_exit_code"
|
exit 0
|
||||||
} 2>&1 | if [ "$use_prefix" = true ]; then prefix_output "BACKEND" "$GREEN"; else cat; fi | tee "$log_file" || {
|
) 2>&1 | if [ "$use_prefix" = true ]; then prefix_output "BACKEND" "$GREEN"; else cat; fi | tee "$log_file"
|
||||||
exit_code=$?
|
|
||||||
log_error "Backend job failed with exit code $exit_code"
|
return ${PIPESTATUS[0]}
|
||||||
echo "$exit_code" > "$TEMP_DIR/backend_exit_code"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
run_jobs() {
|
run_jobs() {
|
||||||
local run_parallel=false
|
local run_parallel=false
|
||||||
|
|
||||||
if [ "$RUN_FRONTEND" = true ] && [ "$RUN_BACKEND" = true ]; then
|
if [ "$RUN_FRONTEND" = true ] && [ "$RUN_BACKEND" = true ]; then
|
||||||
run_parallel=true
|
run_parallel=true
|
||||||
log_info "Starting parallel jobs..."
|
log_info "Starting parallel jobs..."
|
||||||
@@ -208,66 +238,72 @@ run_jobs() {
|
|||||||
log_info "Starting job..."
|
log_info "Starting job..."
|
||||||
fi
|
fi
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
|
local frontend_exit=0
|
||||||
|
local backend_exit=0
|
||||||
|
|
||||||
if [ "$run_parallel" = true ]; then
|
if [ "$run_parallel" = true ]; then
|
||||||
frontend_job true &
|
frontend_job true &
|
||||||
local frontend_pid=$!
|
local frontend_pid=$!
|
||||||
|
|
||||||
backend_job true &
|
backend_job true &
|
||||||
local backend_pid=$!
|
local backend_pid=$!
|
||||||
|
|
||||||
log_info "Frontend PID: $frontend_pid"
|
log_info "Frontend PID: $frontend_pid"
|
||||||
log_info "Backend PID: $backend_pid"
|
log_info "Backend PID: $backend_pid"
|
||||||
log_info "Waiting for jobs to complete..."
|
log_info "Waiting for jobs to complete..."
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
|
set +e
|
||||||
wait $frontend_pid
|
wait $frontend_pid
|
||||||
|
frontend_exit=$?
|
||||||
wait $backend_pid
|
wait $backend_pid
|
||||||
|
backend_exit=$?
|
||||||
|
set -e
|
||||||
else
|
else
|
||||||
if [ "$RUN_FRONTEND" = true ]; then
|
if [ "$RUN_FRONTEND" = true ]; then
|
||||||
|
set +e
|
||||||
frontend_job false
|
frontend_job false
|
||||||
|
frontend_exit=$?
|
||||||
|
set -e
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$RUN_BACKEND" = true ]; then
|
if [ "$RUN_BACKEND" = true ]; then
|
||||||
|
set +e
|
||||||
backend_job false
|
backend_job false
|
||||||
|
backend_exit=$?
|
||||||
|
set -e
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
local frontend_exit=0
|
|
||||||
local backend_exit=0
|
|
||||||
|
|
||||||
if [ "$RUN_FRONTEND" = true ]; then
|
|
||||||
frontend_exit=$(cat "$TEMP_DIR/frontend_exit_code" 2>/dev/null || echo "1")
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$RUN_BACKEND" = true ]; then
|
|
||||||
backend_exit=$(cat "$TEMP_DIR/backend_exit_code" 2>/dev/null || echo "1")
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "==================== JOB SUMMARY ===================="
|
echo "==================== JOB SUMMARY ===================="
|
||||||
|
|
||||||
|
local has_failure=false
|
||||||
|
|
||||||
if [ "$RUN_FRONTEND" = true ]; then
|
if [ "$RUN_FRONTEND" = true ]; then
|
||||||
if [ "$frontend_exit" -eq 0 ]; then
|
if [ "$frontend_exit" -eq 0 ]; then
|
||||||
log_success "Frontend job completed successfully"
|
log_success "Frontend job completed successfully"
|
||||||
else
|
else
|
||||||
log_error "Frontend job failed with exit code $frontend_exit"
|
log_error "Frontend job failed with exit code $frontend_exit"
|
||||||
|
has_failure=true
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$RUN_BACKEND" = true ]; then
|
if [ "$RUN_BACKEND" = true ]; then
|
||||||
if [ "$backend_exit" -eq 0 ]; then
|
if [ "$backend_exit" -eq 0 ]; then
|
||||||
log_success "Backend job completed successfully"
|
log_success "Backend job completed successfully"
|
||||||
else
|
else
|
||||||
log_error "Backend job failed with exit code $backend_exit"
|
log_error "Backend job failed with exit code $backend_exit"
|
||||||
|
has_failure=true
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$frontend_exit" -ne 0 ] || [ "$backend_exit" -ne 0 ]; then
|
if [ "$has_failure" = true ]; then
|
||||||
log_error "One or more jobs failed. Aborting pipeline."
|
log_error "One or more jobs failed. Aborting pipeline."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_success "All jobs completed successfully"
|
log_success "All jobs completed successfully"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -281,7 +317,7 @@ deploy() {
|
|||||||
echo "==================== DEPLOYMENT ===================="
|
echo "==================== DEPLOYMENT ===================="
|
||||||
log_info "Starting deployment to server..."
|
log_info "Starting deployment to server..."
|
||||||
|
|
||||||
ssh -F ~/.ssh/config -i ~/.ssh/gitea_deploy -p 32766 -o StrictHostKeyChecking=accept-new deploy@ds218 "sudo /usr/local/bin/deployLegalconsenthub.sh"
|
ssh -i ~/.ssh/gitea_deploy -p 32766 -o StrictHostKeyChecking=accept-new deploy@ds218 "sudo /usr/local/bin/deployLegalconsenthub.sh"
|
||||||
|
|
||||||
log_success "Deployment triggered successfully"
|
log_success "Deployment triggered successfully"
|
||||||
log_success "Application is being deployed to production"
|
log_success "Application is being deployed to production"
|
||||||
|
|||||||
Reference in New Issue
Block a user