57 lines
2 KiB
YAML
57 lines
2 KiB
YAML
name: CI/CD Pipeline
|
|
|
|
on:
|
|
push:
|
|
branches:
|
|
- master
|
|
|
|
jobs:
|
|
build-and-deploy:
|
|
runs-on: shell
|
|
steps:
|
|
- name: Clone repository
|
|
run: git clone --depth 1 "http://192.168.8.174:3000/${GITHUB_REPOSITORY}.git" .
|
|
env:
|
|
GIT_TERMINAL_PROMPT: '0'
|
|
|
|
- name: Ensure Docker CLI
|
|
run: |
|
|
apk add --no-cache docker-cli docker-cli-compose openssh-client || true
|
|
grep -q '^vrubel:' /etc/passwd || echo 'vrubel:x:1000:1000::/data:/bin/sh' >> /etc/passwd
|
|
|
|
- name: Setup .env for CI/CD
|
|
run: cp .env.example .env
|
|
|
|
- name: Build Docker image
|
|
run: docker build -t 192.168.8.174:3000/vrubel/schedule-son:latest .
|
|
|
|
- name: Test container
|
|
run: |
|
|
mkdir -p data
|
|
docker run -d --name schedule-test \
|
|
-p 8123:8000 \
|
|
-v $(pwd)/data:/app/data \
|
|
--env-file .env \
|
|
-e TZ=Europe/Moscow \
|
|
-e DATABASE_PATH=/app/data/schedule.db \
|
|
192.168.8.174:3000/vrubel/schedule-son:latest
|
|
|
|
- name: Verify container
|
|
run: |
|
|
sleep 5
|
|
docker logs schedule-test --tail=20
|
|
|
|
- name: Stop container
|
|
run: docker rm -f schedule-test
|
|
|
|
- name: Login to Gitea Container Registry
|
|
run: echo "${{ secrets.REGISTRY_TOKEN }}" | docker login http://192.168.8.174:3000 -u "${{ secrets.REGISTRY_USER }}" --password-stdin
|
|
|
|
- name: Push image to registry
|
|
run: docker push 192.168.8.174:3000/vrubel/schedule-son:latest
|
|
|
|
- name: Copy docker-compose to prod host
|
|
run: scp -i /data/.ssh/id_ed25519 -o StrictHostKeyChecking=no docker-compose.prod.yml vrubel@192.168.8.171:~/services/scheduleSon/docker-compose.yml
|
|
|
|
- name: Deploy on prod host
|
|
run: ssh -i /data/.ssh/id_ed25519 -o StrictHostKeyChecking=no vrubel@192.168.8.171 "cd ~/services/scheduleSon && docker pull 192.168.8.174:3000/vrubel/schedule-son:latest && docker compose up -d --remove-orphans"
|