Skip to content

updated flow file

updated flow file #90

Workflow file for this run

name: GCP CI/CD Pipeline
on:
push:
branches:
- '**'
env:
PROJECT_ID: ${{ secrets.GKE_PROJECT }}
SERVICE_ACCOUNT_KEY: ${{ secrets.SERVICE_ACCOUNT_KEY }}
CLUSTER_NAME: blogs-analyzer-cluster
REGION: ${{ secrets.GKE_ZONE }}
REGISTRY_NAME: blogs-analyzer
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
GOOGLE_GEMINI_API_KEY: ${{ secrets.GOOGLE_GEMINI_API_KEY }}
jobs:
# build:
# runs-on: ubuntu-latest
# steps:
# - name: Checkout code
# uses: actions/checkout@v4
#
# # Set up JDK for Java projects
# - name: Set up JDK 21
# uses: actions/setup-java@v4
# with:
# java-version: '21'
# distribution: 'temurin'
# cache: maven
#
# # Set up Node.js for Angular projects
# - name: Set up Node.js
# uses: actions/setup-node@v4
# with:
# node-version: '21'
#
# # Build Java and Angular projects
# - name: Build Projects
# run: |
# SERVICE_NAMES=$(cat projects-changes-deploy.txt)
# echo "Service Names: $SERVICE_NAMES"
# for SERVICE_NAME in $(echo $SERVICE_NAMES | tr ',' ' '); do
# echo "Building $SERVICE_NAME"
# if [ -d "$SERVICE_NAME" ]; then
# cd $SERVICE_NAME
# if [ "$SERVICE_NAME" == "blogs-analyzer-ui" ]; then
# npm install && npm test && npm install -g sonarqube-scanner && npm run sonar
# else
# mvn clean install -Psonar -B -V
# fi
# cd ..
# fi
# done
deploy:

Check failure on line 56 in .github/workflows/gcp.yml

View workflow run for this annotation

GitHub Actions / GCP CI/CD Pipeline

Invalid workflow file

The workflow is not valid. .github/workflows/gcp.yml (Line: 56, Col: 3): The workflow must contain at least one job with no dependencies.
runs-on: ubuntu-latest
needs: build
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Setup Google Cloud SDK
uses: google-github-actions/[email protected]
with:
project_id: ${{ env.GKE_PROJECT }}
service_account_key: ${{ env.SERVICE_ACCOUNT_KEY }}
- name: Authenticate to Google Cloud
id: auth
uses: google-github-actions/[email protected]
with:
credentials_json: ${{ env.SERVICE_ACCOUNT_KEY }}
- name: Configure Docker for Google Container Registry
run: gcloud auth configure-docker
- name: Install gke-gcloud-auth-plugin
run: |
gcloud components install gke-gcloud-auth-plugin
# Setup for Java projects
- name: Set up JDK 21
uses: actions/setup-java@v4
with:
java-version: '21'
distribution: 'temurin'
cache: maven
#
# - name: Build and Push Docker Images
# run: |
# COMMIT_SHA=$(git rev-parse --short HEAD)
# SERVICE_NAMES=$(cat projects-changes-deploy.txt)
# echo "Service Names: $SERVICE_NAMES"
# for SERVICE_NAME in $(echo $SERVICE_NAMES | tr ',' ' '); do
# echo "Building and pushing Docker image for $SERVICE_NAME"
# if [ -d "$SERVICE_NAME" ]; then
# cd $SERVICE_NAME
# if [ "$SERVICE_NAME" != "blogs-analyzer-ui" ]; then
# mvn clean install -DskipTests
# fi
# IMAGE_NAME=gcr.io/gen-lang-client-0999974873/$SERVICE_NAME:$COMMIT_SHA
# docker build -t $IMAGE_NAME .
# docker push $IMAGE_NAME
# cd ..
# fi
# done
- name: Check environment variables
run: |
echo "PROJECT_ID=$PROJECT_ID"
echo "SERVICE_ACCOUNT_KEY=$SERVICE_ACCOUNT_KEY"
echo "CLUSTER_NAME=$CLUSTER_NAME"
echo "REGION=$REGION"
echo "REGISTRY_NAME=$REGISTRY_NAME"
echo "SONAR_TOKEN=$SONAR_TOKEN"
echo "GOOGLE_GEMINI_API_KEY=$GOOGLE_GEMINI_API_KEY"
- name: Deploy to GKE
run: |
echo "Getting credentials for cluster $CLUSTER_NAME in zone $REGION"
gcloud container clusters get-credentials $CLUSTER_NAME --region $REGION --project $PROJECT_ID
COMMIT_SHA=$(git rev-parse --short HEAD)
SERVICE_NAMES=$(cat projects-changes-deploy.txt)
echo "Service Names: $SERVICE_NAMES"
for SERVICE_NAME in $(echo $SERVICE_NAMES | tr ',' ' '); do
echo "Deploying $SERVICE_NAME to GKE"
if [ -d "$SERVICE_NAME/k8s" ]; then
sed -i "s|gcr.io/gen-lang-client-0999974873/$SERVICE_NAME:latest|gcr.io/gen-lang-client-0999974873/$SERVICE_NAME:$COMMIT_SHA|g" $SERVICE_NAME/k8s/deployment.yaml
kubectl apply -f $SERVICE_NAME/k8s/
fi
done