fix: improve woodpecker pipeline (validate env + healthcheck loop)

- Add PS_ADMIN_FOLDER to validate step environment
- Replace fixed sleep with retry loop (6min max, exit on success)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
syoul
2026-03-17 13:05:43 +01:00
parent 650e19273b
commit 6f03e981b8

View File

@@ -11,6 +11,7 @@ steps:
- /var/run/docker.sock:/var/run/docker.sock - /var/run/docker.sock:/var/run/docker.sock
environment: environment:
PS_DOMAIN: presta.syoul.fr PS_DOMAIN: presta.syoul.fr
PS_ADMIN_FOLDER: admin-secure
DB_PASSWORD: placeholder DB_PASSWORD: placeholder
DB_ROOT_PASSWORD: placeholder DB_ROOT_PASSWORD: placeholder
PRESTASHOP_ADMIN_EMAIL: placeholder PRESTASHOP_ADMIN_EMAIL: placeholder
@@ -34,16 +35,37 @@ steps:
# Etape 3 : Deploiement sur sonic via Docker socket # Etape 3 : Deploiement sur sonic via Docker socket
deploy: deploy:
image: docker:27-cli image: docker:27-cli
environment:
PS_DOMAIN:
from_secret: PS_DOMAIN
PS_ADMIN_FOLDER:
from_secret: PS_ADMIN_FOLDER
PRESTASHOP_ADMIN_EMAIL:
from_secret: PRESTASHOP_ADMIN_EMAIL
PRESTASHOP_ADMIN_PASSWORD:
from_secret: PRESTASHOP_ADMIN_PASSWORD
DB_ROOT_PASSWORD:
from_secret: DB_ROOT_PASSWORD
DB_PASSWORD:
from_secret: DB_PASSWORD
volumes: volumes:
# Acces au Docker socket de l'hote (sonic)
- /var/run/docker.sock:/var/run/docker.sock - /var/run/docker.sock:/var/run/docker.sock
# Dossier de deploiement sur l'hote (contient le .env)
- /opt/prestashop:/opt/prestashop - /opt/prestashop:/opt/prestashop
commands: commands:
# Copier le docker-compose.yml vers le dossier de deploiement # Generer le .env sur le serveur a partir des secrets Woodpecker
# Woodpecker est la source de verite unique pour tous les secrets
- |
cat > /opt/prestashop/.env << EOF
PS_DOMAIN=${PS_DOMAIN}
PS_ADMIN_FOLDER=${PS_ADMIN_FOLDER}
PRESTASHOP_ADMIN_EMAIL=${PRESTASHOP_ADMIN_EMAIL}
PRESTASHOP_ADMIN_PASSWORD=${PRESTASHOP_ADMIN_PASSWORD}
DB_ROOT_PASSWORD=${DB_ROOT_PASSWORD}
DB_PASSWORD=${DB_PASSWORD}
EOF
- chmod 600 /opt/prestashop/.env
# Deployer
- cp docker-compose.yml /opt/prestashop/docker-compose.yml - cp docker-compose.yml /opt/prestashop/docker-compose.yml
# Lancer/mettre a jour la stack depuis le dossier de deploiement
# (le .env doit deja etre present dans /opt/prestashop/.env sur sonic)
- cd /opt/prestashop && docker compose pull - cd /opt/prestashop && docker compose pull
- cd /opt/prestashop && docker compose up -d --remove-orphans - cd /opt/prestashop && docker compose up -d --remove-orphans
- cd /opt/prestashop && docker compose ps - cd /opt/prestashop && docker compose ps
@@ -55,16 +77,22 @@ steps:
PS_DOMAIN: PS_DOMAIN:
from_secret: PS_DOMAIN from_secret: PS_DOMAIN
commands: commands:
- echo "Attente du demarrage de PrestaShop..."
- sleep 90
- | - |
HTTP_CODE=$(curl -sSo /dev/null -w "%{http_code}" "http://${PS_DOMAIN}" || echo "000") echo "Attente du demarrage de PrestaShop (max 6 minutes)..."
echo "HTTP Status: ${HTTP_CODE}" MAX=36
if [ "${HTTP_CODE}" != "200" ] && [ "${HTTP_CODE}" != "301" ] && [ "${HTTP_CODE}" != "302" ]; then i=0
echo "ERREUR: PrestaShop ne repond pas correctement (code ${HTTP_CODE})" until [ $i -ge $MAX ]; do
exit 1 HTTP_CODE=$(curl -sSo /dev/null -w "%{http_code}" "http://${PS_DOMAIN}" 2>/dev/null || echo "000")
fi echo "Tentative $((i+1))/${MAX} - HTTP ${HTTP_CODE}"
echo "PrestaShop repond correctement" if [ "${HTTP_CODE}" = "200" ] || [ "${HTTP_CODE}" = "301" ] || [ "${HTTP_CODE}" = "302" ]; then
echo "PrestaShop repond correctement"
exit 0
fi
i=$((i+1))
sleep 10
done
echo "ERREUR: PrestaShop ne repond pas apres 6 minutes"
exit 1
# Notification en cas d'echec # Notification en cas d'echec
notify-failure: notify-failure: