Skip to content

๐Ÿ”ง ๊ฐœ๋ฐœ์ž์šฉ ์• ํ”Œ๊ณ„์ • sub๊ฐ’์„ ๋ณด๊ธฐ์œ„ํ•œ ์ž„์‹œ ๋กœ๊ทธ ์ถ”๊ฐ€ #162

๐Ÿ”ง ๊ฐœ๋ฐœ์ž์šฉ ์• ํ”Œ๊ณ„์ • sub๊ฐ’์„ ๋ณด๊ธฐ์œ„ํ•œ ์ž„์‹œ ๋กœ๊ทธ ์ถ”๊ฐ€

๐Ÿ”ง ๊ฐœ๋ฐœ์ž์šฉ ์• ํ”Œ๊ณ„์ • sub๊ฐ’์„ ๋ณด๊ธฐ์œ„ํ•œ ์ž„์‹œ ๋กœ๊ทธ ์ถ”๊ฐ€ #162

Workflow file for this run

name: Java CI with Gradle
on:
push:
branches: [ "main" ]
pull_request:
branches: [ "main" ]
env:
AWS_REGION: ap-northeast-2
AWS_S3_BUCKET: ${{ secrets.AWS_BUCKET_NAME }}
AWS_CODE_DEPLOY_APPLICATION: mapddang-CD
AWS_CODE_DEPLOY_GROUP: mapddang-CD-group
MYSQL_URL: ${{ secrets.MYSQL_URL }}
MYSQL_USERNAME: ${{ secrets.MYSQL_USERNAME }}
MYSQL_PASSWORD: ${{ secrets.MYSQL_PASSWORD }}
APPLE_CLIENT_ID: ${{ secrets.APPLE_CLIENT_ID }}
APPLE_KEY_ID: ${{ secrets.APPLE_KEY_ID }}
APPLE_TEAM_ID: ${{ secrets.APPLE_TEAM_ID }}
APPLE_PRIVATE_KEY: ${{ secrets.APPLE_PRIVATE_KEY }}
JWT_SECRET_KEY: ${{ secrets.JWT_SECRET_KEY }}
ACCESS_TOKEN_EXPIRE: ${{ secrets.ACCESS_TOKEN_EXPIRE }}
REFRESH_TOKEN_EXPIRE: ${{ secrets.REFRESH_TOKEN_EXPIRE }}
AWS_S3_ACCESS_KEY: ${{ secrets.AWS_S3_ACCESS_KEY }}
AWS_S3_SECRET_KEY: ${{ secrets.AWS_S3_SECRET_KEY }}
jobs:
build-with-gradle:
runs-on: ubuntu-latest
permissions:
contents: read
steps:
- uses: actions/checkout@v4
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'corretto'
#๋นŒ๋“œ ์บ์‹œ
- name: Cache Gradle packages
uses: actions/cache@v2
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: ${{ runner.os }}-gradle-
#gradlew ํŒŒ์ผ์— ์‹คํ–‰ ๊ถŒํ•œ ๋ถ€์—ฌ
- name: Grant execute permission to gradlew
run: chmod +x ./gradlew
#todo build + test
#ํ”„๋กœ์ ํŠธ ๋นŒ๋“œ
- name: Build Project
run: ./gradlew clean build -x test
#AWS ์ž๊ฒฉ์ฆ๋ช… ์„ค์ •
- name: Setup AWS credential
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_S3_ACCESS_KEY }}
aws-secret-access-key: ${{ secrets.AWS_S3_SECRET_KEY }}
aws-region: ap-northeast-2
#ZIP ํŒŒ์ผ์„ S3 ๋ฒ„ํ‚ท์— ์—…๋กœ๋“œ
- name: Upload to AWS S3
run: |
aws deploy push \
--application-name ${{ env.AWS_CODE_DEPLOY_APPLICATION }} \
--ignore-hidden-files \
--s3-location s3://$AWS_S3_BUCKET/cicdtest/$GITHUB_SHA.zip \
--source .
#์—…๋กœ๋“œ๋œ ZIP ํŒŒ์ผ์„ CodeDeploy๋กœ ๋ฐฐํฌ
- name: AWS Code Deploy
run: |
aws deploy create-deployment \
--application-name ${{ env.AWS_CODE_DEPLOY_APPLICATION }} \
--deployment-config-name CodeDeployDefault.AllAtOnce \
--deployment-group-name ${{ env.AWS_CODE_DEPLOY_GROUP }} \
--s3-location bucket=$AWS_S3_BUCKET,bundleType=zip,key=cicdtest/$GITHUB_SHA.zip