57 lines
1.8 KiB
YAML
57 lines
1.8 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: which docker || apk add --no-cache docker-cli docker-cli-compose
|
|
|
|
- name: Setup .env for CI/CD
|
|
run: cp .env.example .env
|
|
|
|
- name: Build Docker image
|
|
run: docker compose build
|
|
|
|
- name: Start container for test
|
|
run: docker compose up -d
|
|
|
|
- name: Verify bot running
|
|
run: |
|
|
sleep 5
|
|
docker compose logs --tail=20
|
|
|
|
- name: Stop container
|
|
run: docker compose down
|
|
|
|
- name: Login to Gitea Container Registry
|
|
run: |
|
|
echo "=== whoami: $(whoami) ==="
|
|
echo "=== HOME: $HOME ==="
|
|
echo "=== DOCKER_HOST: ${DOCKER_HOST:-unset} ==="
|
|
echo "=== docker version ==="
|
|
docker --version
|
|
echo "=== docker info insecure ==="
|
|
docker info 2>&1 | grep -A3 Insecure || echo "no insecure info"
|
|
echo "=== attempting login ==="
|
|
echo "${{ secrets.REGISTRY_TOKEN }}" | docker login http://192.168.8.174:3000 -u "${{ secrets.REGISTRY_USER }}" --password-stdin 2>&1
|
|
echo "=== exit code: $? ==="
|
|
|
|
- name: Push image to registry
|
|
run: docker push 192.168.8.174:3000/vrubel/t2s-telegram-bot:latest
|
|
|
|
- name: Copy docker-compose to prod host
|
|
run: scp docker-compose.prod.yml 192.168.8.171:~/services/t2sTelegramBot/docker-compose.yml
|
|
|
|
- name: Deploy on prod host
|
|
run: ssh 192.168.8.171 "cd ~/services/t2sTelegramBot && docker compose pull && docker compose up -d --remove-orphans"
|