test connection to documentdb #59
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI/CD Pipeline | |
on: | |
push: | |
branches: | |
- master | |
pull_request: | |
types: [opened, synchronize, reopened] | |
workflow_dispatch: | |
permissions: | |
id-token: write | |
contents: read | |
env: | |
APPLICATION_NAME: spring-boot-example | |
AWS_REGION: eu-west-1 | |
AWS_ECS_CLUSTER_NAME: ecs-eu-west-1-nonprod | |
AWS_ECS_SERVICE_NAME: ecs-eu-west-1-nonprod | |
AWS_ECS_TASK_DEFINITION_NAME: ecs-eu-west-1-nonprod | |
DOCUMENTDB_DATABASE: test | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
- name: Set up JDK 22 | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'adopt' | |
java-version: '21' | |
- name: Build with Maven | |
run: mvn clean install | |
- name: Configure aws credentials | |
uses: aws-actions/configure-aws-credentials@v2 | |
with: | |
role-to-assume: arn:aws:iam::654654270781:role/github-actions | |
aws-region: ${{ env.AWS_REGION }} | |
- name: Log in to Amazon ECR | |
id: login-ecr | |
uses: aws-actions/amazon-ecr-login@v2 | |
- name: Extract Git commit SHA | |
id: git-info | |
run: | | |
echo "COMMIT_SHA=$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT | |
echo "COMMIT_SHA=$(git rev-parse --short HEAD)" >> $GITHUB_ENV | |
- name: Build Docker image | |
run: | | |
docker build -t ${{ env.APPLICATION_NAME }}:${{ env.COMMIT_SHA }} . | |
docker tag ${{ env.APPLICATION_NAME }}:${{ env.COMMIT_SHA }} ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.${{ env.AWS_REGION }}.amazonaws.com/${{ env.APPLICATION_NAME }}:${{ env.COMMIT_SHA }} | |
docker tag ${{ env.APPLICATION_NAME }}:${{ env.COMMIT_SHA }} ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.${{ env.AWS_REGION }}.amazonaws.com/${{ env.APPLICATION_NAME }}:latest | |
- name: Push Docker image to ECR | |
run: | | |
docker push ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.${{ env.AWS_REGION }}.amazonaws.com/${{ env.APPLICATION_NAME }}:${{ env.COMMIT_SHA }} | |
docker push ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.${{ env.AWS_REGION }}.amazonaws.com/${{ env.APPLICATION_NAME }}:latest | |
outputs: | |
commit_sha: ${{ steps.git-info.outputs.COMMIT_SHA }} | |
deploy: | |
needs: build | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v3 | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v2 | |
with: | |
role-to-assume: arn:aws:iam::654654270781:role/github-actions | |
aws-region: ${{ env.AWS_REGION }} | |
- name: Register new task definition revision | |
id: task-def | |
run: | | |
SHA="${{ needs.build.outputs.commit_sha }}" | |
export TASK_DEFINITION=$(cat config/task-definition.json) | |
export UPDATED_TASK_DEFINITION=$(echo $TASK_DEFINITION | jq \ | |
--arg IMAGE "${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.${{ env.AWS_REGION }}.amazonaws.com/${{ env.APPLICATION_NAME }}:$SHA" \ | |
--arg DOCUMENTDB_PASSWORD "${{ secrets.DOCUMENTDB_PASSWORD }}" \ | |
--arg DOCUMENTDB_DATABASE "$DOCUMENTDB_DATABASE" \ | |
'.containerDefinitions[0].environment += [{"name": "DOCUMENTDB_PASSWORD", "value": $DOCUMENTDB_PASSWORD}] | .containerDefinitions[0].environment += [{"name": "DOCUMENTDB_DATABASE", "value": $DOCUMENTDB_DATABASE}] | .containerDefinitions[0].image = $IMAGE') | |
echo $UPDATED_TASK_DEFINITION > new-task-def.json | |
aws ecs register-task-definition --cli-input-json file://new-task-def.json | |
- name: Update ECS service with new task definition | |
run: | | |
aws ecs update-service --cluster ${{ env.AWS_ECS_CLUSTER_NAME }} \ | |
--service ${{ env.AWS_ECS_SERVICE_NAME }} \ | |
--task-definition ${{ env.AWS_ECS_TASK_DEFINITION_NAME }} |