[feat] check the deployment #24
This file contains hidden or 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: Docker CI/CD Pipeline | |
| on: | |
| push: | |
| branches: [main, develop] | |
| pull_request: | |
| branches: [main, develop] | |
| workflow_dispatch: | |
| concurrency: | |
| group: ${{ github.workflow }}-${{ github.ref }} | |
| cancel-in-progress: true | |
| env: | |
| NODE_VERSION: "22.11.0" | |
| DOCKERHUB_REPO: ${{ secrets.DOCKER_USERNAME }}/${{ secrets.DOCKERHUB_PROJECT_NAME }} | |
| jobs: | |
| # Step 1: Code Quality Checks | |
| lint: | |
| name: Lint Code | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout code | |
| uses: actions/checkout@v4 | |
| - name: Setup Node.js | |
| uses: actions/setup-node@v4 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| cache: npm | |
| - name: Install dependencies | |
| run: npm ci | |
| - name: Run ESLint | |
| run: npm run lint | |
| # Step 2: Run Tests | |
| test: | |
| name: Run Tests | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout code | |
| uses: actions/checkout@v4 | |
| - name: Setup Node.js | |
| uses: actions/setup-node@v4 | |
| with: | |
| node-version: ${{ env.NODE_VERSION }} | |
| cache: npm | |
| - name: Install dependencies | |
| run: npm ci | |
| - name: Run tests with coverage | |
| run: npm run test:coverage | |
| - name: Upload coverage reports | |
| uses: actions/upload-artifact@v4 | |
| if: always() | |
| with: | |
| name: coverage-report | |
| path: coverage/ | |
| retention-days: 7 | |
| # Step 3: Build and Deploy (only on main branch) | |
| # build-and-deploy: | |
| # name: Build & Deploy to Docker Hub | |
| # runs-on: ubuntu-latest | |
| # needs: [lint, test] | |
| # steps: | |
| # - name: Checkout code | |
| # uses: actions/checkout@v4 | |
| # - name: Set up QEMU | |
| # uses: docker/setup-qemu-action@v3 | |
| # - name: Set up Docker Buildx | |
| # uses: docker/setup-buildx-action@v3 | |
| # - name: Extract metadata | |
| # id: meta | |
| # run: | | |
| # echo "short_sha=${GITHUB_SHA::7}" >> "$GITHUB_OUTPUT" | |
| # echo "date=$(date +'%Y%m%d')" >> "$GITHUB_OUTPUT" | |
| # - name: Log in to Docker Hub | |
| # uses: docker/login-action@v3 | |
| # with: | |
| # username: ${{ secrets.DOCKER_USERNAME }} | |
| # password: ${{ secrets.DOCKERHUB_TOKEN }} | |
| # - name: Build and push production image | |
| # uses: docker/build-push-action@v6 | |
| # with: | |
| # context: . | |
| # file: Dockerfile | |
| # push: true | |
| # platforms: linux/amd64,linux/arm64 | |
| # tags: | | |
| # ${{ env.DOCKERHUB_REPO }}:latest | |
| # ${{ env.DOCKERHUB_REPO }}:${{ steps.meta.outputs.short_sha }} | |
| # ${{ env.DOCKERHUB_REPO }}:${{ steps.meta.outputs.date }} | |
| # cache-from: type=gha | |
| # cache-to: type=gha,mode=max | |
| # Step 4: Build and Deploy to AWS | |
| build-and-deploy: | |
| name: Build & Deploy to AWS ECS Fargate | |
| runs-on: ubuntu-latest | |
| needs: [lint, test] | |
| # Only run on develop branch (For test purposes). To be replaced with main branch when ready. | |
| if: github.event_name == 'push' && github.ref == 'refs/heads/develop' | |
| steps: | |
| - name: Checkout code | |
| uses: actions/checkout@v4 | |
| - 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: Login to Amazon ECR | |
| id: login-ecr | |
| uses: aws-actions/amazon-ecr-login@v2 | |
| - name: Extract metadata | |
| id: meta | |
| run: | | |
| echo "short_sha=${GITHUB_SHA::7}" >> "$GITHUB_OUTPUT" | |
| echo "date=$(date +'%Y%m%d')" >> "$GITHUB_OUTPUT" | |
| - name: Build Docker image | |
| id: build-image | |
| env: | |
| ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }} | |
| run: | | |
| IMAGE_TAG=${{ steps.meta.outputs.short_sha }} | |
| ECR_IMAGE=$ECR_REGISTRY/${{ secrets.ECR_REPOSITORY_NAME }}:$IMAGE_TAG | |
| docker build -t $ECR_IMAGE . | |
| echo "ECR_IMAGE=$ECR_IMAGE" >> $GITHUB_ENV | |
| - name: Push image to ECR | |
| run: | | |
| docker push $ECR_IMAGE | |
| - name: Deploy to Amazon ECS | |
| run: | | |
| aws ecs update-service \ | |
| --cluster "${{ secrets.ECS_CLUSTER_NAME }}" \ | |
| --service "${{ secrets.ECS_SERVICE_NAME }}" \ | |
| --force-new-deployment \ | |
| --region ${{ secrets.AWS_REGION }} | |