Skip to content

chore: workflow job 순차 수행으로 변경 #3

chore: workflow job 순차 수행으로 변경

chore: workflow job 순차 수행으로 변경 #3

Workflow file for this run

name: Test
on:
pull_request:
branches: [ "main" ]
push:
branches: [ "main" ]
env:
# 버킷에 저장할 폴더 이름
PROJECT_NAME: ledger
# S3 버킷 이름
BUCKET_NAME: newdealledger
# CodeDeploy의 애플리케이션 이름
CODE_DEPLOY_APP_NAME: newdeal-ledger
# CodeDeploy의 배포그룹 이름
DEPLOYMENT_GROUP_NAME: newdeal-ledger-deployment-group
jobs:
build:
# 실행 환경 설정
runs-on: ubuntu-latest
# 차례대로 실행
steps:
- uses: actions/checkout@v2
- name: Set up JDK 17
uses: actions/setup-java@v1
with:
java-version: 17
- name: Grant execute permission for gradlew
run: chmod +x gradlew
# Gradle build (Test 제외)
- name: Build with Gradle
run: ./gradlew clean build -x test
# 압축 파일 만들기
- name: Make Zip File
run: zip -qq -r ./$GITHUB_SHA.zip .
shell: bash
# AWS 인증
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ap-northeast-2
# S3 버킷으로 파일을 업로드
- name: Upload to S3
run: aws s3 cp --region ap-northeast-2 ./$GITHUB_SHA.zip s3://$BUCKET_NAME/$PROJECT_NAME/$GITHUB_SHA.zip
# S3 버킷에 업로드 된 파일을 대상으로 CodeDeploy에서 배포 요청
- name: Code Deploy
run: aws deploy create-deployment --application-name $CODE_DEPLOY_APP_NAME --deployment-config-name CodeDeployDefault.OneAtATime --deployment-group-name $DEPLOYMENT_GROUP_NAME --s3-location bucket=$BUCKET_NAME,bundleType=zip,key=$PROJECT_NAME/$GITHUB_SHA.zip
deploy:
runs-on: ubuntu-latest
needs: build
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up environment variables
run: |
echo "DEV_DB_URL=${{ secrets.DEV_DB_URL }}" >> $GITHUB_ENV
echo "DEV_DB_USER=${{ secrets.DEV_DB_USER }}" >> $GITHUB_ENV
echo "DEV_DB_PASSWORD=${{ secrets.DEV_DB_PASSWORD }}" >> $GITHUB_ENV
- name: Deploy application
run: |
chmod +x ./scripts/start.sh
./scripts/start.sh
env:
DEV_DB_URL: ${{ secrets.DEV_DB_URL }}
DEV_DB_USER: ${{ secrets.DEV_DB_USER }}
DEV_DB_PASSWORD: ${{ secrets.DEV_DB_PASSWORD }}