Skip to content

Dockerized the project #4

Dockerized the project

Dockerized the project #4

Workflow file for this run

name: CI Workflow
on:
push:
branches:
- main
- dev
pull_request:
branches:
- main
- dev
jobs:
# Job for building the backend (Go)
backend:
name: Build Backend (Go)
runs-on: ubuntu-latest
steps:
# Step 1: Checkout the code
- name: Checkout Code
uses: actions/checkout@v3
# Step 2: Set up Go environment
- name: Set up Go
uses: actions/setup-go@v4
with:
go-version: '1.23'
# Step 3: Cache Go modules for faster builds
- name: Cache Go Modules
uses: actions/cache@v3
with:
path: ~/go/pkg/mod
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-
# Step 4: Install Go dependencies
- name: Install Go Dependencies
run: go mod tidy
# Step 5: Build the Go application
- name: Build Go Application
run: go build -o app ./main.go
# Job for building the frontend (React)
frontend:
name: Build Frontend (React)
runs-on: ubuntu-latest
steps:
# Step 1: Checkout the code
- name: Checkout Code
uses: actions/checkout@v3
# Step 2: Set up Node.js environment
- name: Set up Node.js
uses: actions/setup-node@v3
with:
node-version: '18'
# Step 3: Cache Node.js dependencies
- name: Cache Node.js Modules
uses: actions/cache@v3
with:
path: client/node_modules
key: ${{ runner.os }}-node-${{ hashFiles('client/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
# Step 4: Install frontend dependencies
- name: Install Dependencies
working-directory: ./client
run: npm install
# Step 5: Build for production
- name: Build Frontend
working-directory: ./client
run: npm run build