Skip to content

chore: add cicd docker compose #10

chore: add cicd docker compose

chore: add cicd docker compose #10

Workflow file for this run

name: Docker Compose Pipeline
on:
push:
branches:
- main
- staging
pull_request:
branches:
- main
- staging
jobs:
test:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up Docker Compose
run: |
sudo apt-get update
sudo apt-get install -y docker-compose
- name: Create Environment Files
run: |
cd ./apps/frontend
echo "NEXT_PUBLIC_QUESTION_SERVICE_URL=${{ env.QUESTION_SERVICE_URL }}" >> .env
echo "NEXT_PUBLIC_USER_SERVICE_URL=${{ env.USER_SERVICE_URL }}" >> .env
cd ../question-service
echo "FIREBASE_CREDENTIAL_PATH=${{ env.QUESTION_SERVICE_FIREBASE_CREDENTIAL_PATH }}" >> .env
echo "JWT_SECRET=${{ secrets.JWT_SECRET }}" >> .env
cd ../user-service
echo "DB_CLOUD_URI=${{ env.USER_SERVICE_DB_CLOUD_URI }}" >> .env
echo "PORT=${{ env.USER_SERVICE_PORT }}" >> .env
echo "JWT_SECRET=${{ secrets.JWT_SECRET }}" >> .env
- name: Build and Run Services
run: |
cd ./apps
docker-compose up --build -d
- name: Clean up environment files
run: |
rm ./apps/frontend/.env
rm ./apps/question-service/.env
rm ./apps/user-service/.env
- name: Wait for services to be ready
run: sleep 10
- name: Run Tests
run: |
# check if non-error status code received
curl --fail ${{ env.FRONTEND_URL }}
curl --fail ${{ env.USER_SERVICE_URL }}
# check if any response received
curl -s -o /dev/null ${{ env.QUESTION_SERVICE_URL }}
# We can add more tests here
- name: Stop Services
run: |
cd .apps
docker-compose down