Files
prestashop-test/.woodpecker.yml
syoul 295e96367e
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
debug: test volumes + from_secret sur docker:27-cli
2026-03-17 18:38:31 +01:00

110 lines
3.5 KiB
YAML

when:
- branch: main
event: push
steps:
# Etape 1 : Validation syntaxique du docker-compose.yml
- name: validate
image: docker:27-cli
volumes:
- /var/run/docker.sock:/var/run/docker.sock
environment:
PS_DOMAIN: presta.syoul.fr
PS_ADMIN_FOLDER: admin-secure
DB_PASSWORD: placeholder
DB_ROOT_PASSWORD: placeholder
PRESTASHOP_ADMIN_EMAIL: placeholder
PRESTASHOP_ADMIN_PASSWORD: placeholder
commands:
- docker compose config --quiet
- echo "docker-compose.yml valide"
# Etape 2 : Verifications de securite
- name: security-check
image: alpine:3.20
commands:
- |
if [ -f .env ]; then
echo "ERREUR: .env ne doit pas etre commite dans le depot !"
exit 1
fi
- 'grep -q "^\.env$" .gitignore || (echo "ERREUR: .env manquant dans .gitignore" && exit 1)'
- echo "Verifications de securite OK"
# Debug : volumes + from_secret
- name: debug-volumes-secret
image: docker:27-cli
environment:
PS_DOMAIN:
from_secret: ps_domain
volumes:
- /var/run/docker.sock:/var/run/docker.sock
commands:
- echo "PS_DOMAIN=${PS_DOMAIN}"
# Etape 3 : Deploiement sur sonic via Docker socket
- name: deploy
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:
- /var/run/docker.sock:/var/run/docker.sock
- /opt/prestashop:/opt/prestashop
commands:
- printf 'PS_DOMAIN=%s\nPS_ADMIN_FOLDER=%s\nPRESTASHOP_ADMIN_EMAIL=%s\nPRESTASHOP_ADMIN_PASSWORD=%s\nDB_ROOT_PASSWORD=%s\nDB_PASSWORD=%s\n' "${PS_DOMAIN}" "${PS_ADMIN_FOLDER}" "${PRESTASHOP_ADMIN_EMAIL}" "${PRESTASHOP_ADMIN_PASSWORD}" "${DB_ROOT_PASSWORD}" "${DB_PASSWORD}" > /opt/prestashop/.env
- chmod 600 /opt/prestashop/.env
- cp docker-compose.yml /opt/prestashop/docker-compose.yml
- cd /opt/prestashop && docker compose pull
- cd /opt/prestashop && docker compose up -d --remove-orphans
- cd /opt/prestashop && docker compose ps
# Etape 4 : Healthcheck post-deploiement
- name: healthcheck
image: curlimages/curl:8.11.0
environment:
PS_DOMAIN:
from_secret: ps_domain
commands:
- |
if [ -z "${PS_DOMAIN}" ]; then
echo "ERREUR: PS_DOMAIN non defini, verifier le secret Woodpecker"
exit 1
fi
TARGET="http://${PS_DOMAIN}"
echo "Healthcheck sur ${TARGET} (max 10 minutes)..."
MAX=60
i=0
until [ $i -ge $MAX ]; do
HTTP_CODE=$(curl -sSo /dev/null -w "%{http_code}" "${TARGET}" 2>/dev/null)
echo "Tentative $((i+1))/${MAX} - HTTP ${HTTP_CODE}"
if [ "${HTTP_CODE}" = "200" ] || [ "${HTTP_CODE}" = "301" ] || [ "${HTTP_CODE}" = "302" ]; then
echo "PrestaShop repond correctement sur ${TARGET}"
exit 0
fi
i=$((i+1))
sleep 10
done
echo "ERREUR: PrestaShop ne repond pas apres 10 minutes"
exit 1
# Notification en cas d'echec
- name: notify-failure
image: alpine:3.20
commands:
- 'echo "ECHEC pipeline #${CI_BUILD_NUMBER} sur commit ${CI_COMMIT_SHA}"'
- 'echo "Branche: ${CI_COMMIT_BRANCH}"'
when:
- status: failure