Skip to content

chore: CI/CD 설정을 위한 빌드 스크립트 수정 #7

chore: CI/CD 설정을 위한 빌드 스크립트 수정

chore: CI/CD 설정을 위한 빌드 스크립트 수정 #7

Workflow file for this run

name: Deploy React App to AWS S3 and CloudFront
on:
push:
branches:
- release/v2.0.0
- dev
pull_request:
branches:
- release/v2.0.0
- dev
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Node.js
uses: actions/setup-node@v4
with:
node-version: '18'
- name: Cache npm packages
uses: actions/cache@v4
with:
path: ~/.npm
key: ${{ runner.os }}-npm-${{ hashFiles('package-lock.json') }}
restore-keys: |
${{ runner.os }}-npm
- name: Install dependencies
run: npm ci
- name: Debug dependencies and Webpack config
run: |
echo "Checking installed dependencies..."
npm list webpack html-webpack-plugin
echo "Listing webpack.config.js..."
ls -al ./webpack.config.js
- name: Build the project
env:
NODE_ENV: production
API_URL: ${{ secrets.API_URL }}
CDN_URL: ${{ secrets.CDN_URL }}
run: npm run build
- name: Set up AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ${{ secrets.AWS_REGION }}
- name: Deploy to S3
run: |
aws s3 sync ./dist/ s3://${{ secrets.S3_BUCKET_NAME }} --delete
env:
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_REGION: ${{ secrets.AWS_REGION }}
- name: Invalidate CloudFront cache
uses: chetan/invalidate-cloudfront-action@v2
with:
distribution: ${{ secrets.CLOUDFRONT_DISTRIBUTION_ID }}
paths: "/*"
env:
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_REGION: ${{ secrets.AWS_REGION }}