Skip to content

[Fix] preview.yml 수정 #60

[Fix] preview.yml 수정

[Fix] preview.yml 수정 #60

Workflow file for this run

name: preview-url
permissions:
pull-requests: write
contents: read
on:
pull_request:
branches: [develop]
types: [opened, synchronize, reopened]
jobs:
preview:
runs-on: ubuntu-latest
steps:
- name: Git Checkout
uses: actions/checkout@v4
- name: Check DashboardSection changes
run: |
echo "Git branch info:"
git branch -v
echo "Recent commits:"
git log -3 --oneline
echo "Working directory status:"
git status
- name: Check file content
run: |
echo "DashboardSection.tsx location and content:"
find . -name "DashboardSection.tsx" -exec sh -c 'echo "Location: {}"; cat "{}"' \;
- name: Install pnpm
uses: pnpm/action-setup@v4
with:
version: 8.15.6
- name: Use Node.js
uses: actions/setup-node@v4
with:
node-version: "20.x"
cache: "pnpm"
- name: Install dependencies
run: pnpm install
- name: Generate Environment Variables File
run: |
echo "NEXT_PUBLIC_API_URL=$NEXT_PUBLIC_API_URL" >> apps/web/.env.production.local
env:
NEXT_PUBLIC_API_URL: ${{ secrets.NEXT_PUBLIC_API_URL }}
- name: Clean build and rebuild
run: |
echo "Cleaning Next.js cache..."
rm -rf apps/web/.next
rm -rf apps/web/out
echo "Building again..."
pnpm -filter=web build
env:
GITHUB_EVENT_NAME: ${{ github.event_name }}
GITHUB_EVENT_NUMBER: ${{ github.event.pull_request.number }}
- name: Check build output
run: |
echo "Checking index.html content:"
cat ${{ secrets.BUILD_DIRECTORY }}/index.html
- name: Configure 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 with PR-specific prefix
run: |
echo "Syncing files to S3..."
aws s3 sync ${{ secrets.BUILD_DIRECTORY }} s3://${{ secrets.AWS_S3_BUCKET_NAME }}/pr-${{ github.event.pull_request.number }} --delete
echo "Files uploaded to S3:"
aws s3 ls s3://${{ secrets.AWS_S3_BUCKET_NAME }}/pr-${{ github.event.pull_request.number }} --recursive
- name: CloudFront Invalidate Cache
run: aws cloudfront create-invalidation --distribution-id ${{ secrets.AWS_CLOUDFRONT_DISTRIBUTION_ID }} --paths "/pr-${{ github.event.pull_request.number }}/*"
- name: Add Preview URL as a Comment
uses: marocchino/sticky-pull-request-comment@v2
with:
message: |
## 🚀 Preview URL
**Branch:** ${{ github.head_ref }}
**Commit:** ${{ github.sha }}
Preview URL: https://codeit.click?pr=${{ github.event.pull_request.number }}