Skip to content

chore: add deploy script for project deployment #342

chore: add deploy script for project deployment

chore: add deploy script for project deployment #342

Workflow file for this run

# name: CI
#
# on:
# push:
# branches: [main]
# pull_request:
#
# env:
# PORT: 80
# IPS: '::1'
# NODE_ENV: 'testing'
# OPENAI_API_KEY: 'DEEZ'
# CLAUDE_API_KEY: 'NUTZ'
# DEEPSEEK_API_KEY: 'BALLZ'
# DISCORD_WEBHOOK_URL: 'x'
#
# concurrency:
# group: ${{ github.workflow }}-${{ github.ref }}
# cancel-in-progress: true
#
# jobs:
# test:
# name: Unit tests
# runs-on: ubuntu-latest
#
# strategy:
# matrix:
# node-version: [22.x]
#
# steps:
# - uses: actions/checkout@v3
# - name: Use Node.js ${{ matrix.node-version }}
# uses: actions/setup-node@v3
# with:
# node-version: ${{ matrix.node-version }}
# cache: 'npm'
#
# - name: Create .env file from .env.example
# run: cp .env.example .env
#
# - name: Install dependencies
# run: npm i
#
# - name: Test codes
# run: npm run test:coverage
#
# lint:
# name: ESLint
# runs-on: ubuntu-latest
#
# strategy:
# matrix:
# node-version: [22.x]
#
# steps:
# - uses: actions/checkout@v3
# - name: Use Node.js ${{ matrix.node-version }}
# uses: actions/setup-node@v3
# with:
# node-version: ${{ matrix.node-version }}
# cache: 'npm'
#
# - name: Install dependencies
# run: npm i
#
# - name: Lint codes
# run: npm run lint
#
# format:
# needs: [lint, test]
# name: Prettier format
# runs-on: ubuntu-latest
#
# permissions:
# contents: write
#
# strategy:
# matrix:
# node-version: [22.x]
#
# steps:
# - uses: actions/checkout@v3
# - name: Use Node.js ${{ matrix.node-version }}
# uses: actions/setup-node@v3
# with:
# node-version: ${{ matrix.node-version }}
# cache: 'npm'
#
# - name: Install dependencies
# run: npm i
#
# - name: Format codes
# run: npm run format
#
# - name: Commit changes
# uses: stefanzweifel/git-auto-commit-action@v4
# with:
# commit_message: 'style: format codes'
# env:
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
#
# deploy:
# needs: [test, lint, format]
# name: Deploy to Production
# runs-on: ubuntu-latest
# if: github.event_name == 'push' && github.ref == 'refs/heads/main'
#
# environment:
# name: production
# url: https://commit.jaw.dev/
#
# steps:
# - name: Check out repository
# uses: actions/checkout@v3
#
# - name: Set up Docker Buildx
# uses: docker/setup-buildx-action@v2
#
# - name: Login to Container Registry
# uses: docker/login-action@v2
# with:
# registry: ghcr.io
# username: ${{ github.repository_owner }}
# password: ${{ secrets.GH_TOKEN }}
#
# - name: Preset Image Name
# run: echo "IMAGE_URL=$(echo ghcr.io/${{ github.repository_owner }}/${{ github.event.repository.name }}:$(echo ${{ github.sha }} | cut -c1-7) | tr '[:upper:]' '[:lower:]')" >> $GITHUB_ENV
#
# - name: Build and push Docker Image
# uses: docker/build-push-action@v4
# with:
# context: .
# file: ./Dockerfile.prod
# push: true
# tags: ${{ env.IMAGE_URL }}
#
# - name: Deploy Image to Server
# uses: caprover/deploy-from-github@v1.1.2
# with:
# server: '${{ secrets.CAPROVER_SERVER }}'
# app: '${{ secrets.APP_NAME }}'
# token: '${{ secrets.APP_TOKEN }}'
# image: ${{ env.IMAGE_URL }}