mirror of
https://github.com/frappe/frappe_docker.git
synced 2025-01-10 17:24:43 +00:00
ci: check connections before curl
This commit is contained in:
parent
cb2943bdf7
commit
4f7108c3a8
@ -24,3 +24,63 @@ ping_site() {
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
docker_compose_with_args() {
|
||||||
|
# shellcheck disable=SC2068
|
||||||
|
docker-compose \
|
||||||
|
-p $project_name \
|
||||||
|
-f installation/docker-compose-common.yml \
|
||||||
|
-f installation/docker-compose-frappe.yml \
|
||||||
|
-f installation/frappe-publish.yml \
|
||||||
|
$@
|
||||||
|
}
|
||||||
|
|
||||||
|
check_migration_complete() {
|
||||||
|
print_group Check migration
|
||||||
|
|
||||||
|
container_id=$(docker_compose_with_args ps -q frappe-python)
|
||||||
|
cmd="docker logs ${container_id} 2>&1 | grep 'Starting gunicorn' || echo ''"
|
||||||
|
worker_log=$(eval "$cmd")
|
||||||
|
INCREMENT=0
|
||||||
|
|
||||||
|
while [[ ${worker_log} != *"Starting gunicorn"* && ${INCREMENT} -lt 120 ]]; do
|
||||||
|
sleep 3
|
||||||
|
((INCREMENT = INCREMENT + 1))
|
||||||
|
echo "Wait for migration to complete..."
|
||||||
|
worker_log=$(eval "$cmd")
|
||||||
|
if [[ ${worker_log} != *"Starting gunicorn"* && ${INCREMENT} -eq 120 ]]; then
|
||||||
|
echo Migration timeout
|
||||||
|
docker logs "${container_id}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
echo Migration Log
|
||||||
|
docker logs "${container_id}"
|
||||||
|
}
|
||||||
|
|
||||||
|
check_health() {
|
||||||
|
print_group Loop health check
|
||||||
|
|
||||||
|
docker run --name frappe_doctor \
|
||||||
|
-v "${project_name}_sites-vol:/home/frappe/frappe-bench/sites" \
|
||||||
|
--network "${project_name}_default" \
|
||||||
|
frappe/frappe-worker:edge doctor || true
|
||||||
|
|
||||||
|
cmd='docker logs frappe_doctor | grep "Health check successful" || echo ""'
|
||||||
|
doctor_log=$(eval "$cmd")
|
||||||
|
INCREMENT=0
|
||||||
|
|
||||||
|
while [[ -z "${doctor_log}" && ${INCREMENT} -lt 60 ]]; do
|
||||||
|
sleep 1
|
||||||
|
((INCREMENT = INCREMENT + 1))
|
||||||
|
container=$(docker start frappe_doctor)
|
||||||
|
echo "Restarting ${container}..."
|
||||||
|
doctor_log=$(eval "$cmd")
|
||||||
|
|
||||||
|
if [[ ${INCREMENT} -eq 60 ]]; then
|
||||||
|
docker logs "${container}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
@ -6,66 +6,6 @@ source tests/functions.sh
|
|||||||
|
|
||||||
project_name=frappe_bench_00
|
project_name=frappe_bench_00
|
||||||
|
|
||||||
docker_compose_with_args() {
|
|
||||||
# shellcheck disable=SC2068
|
|
||||||
docker-compose \
|
|
||||||
-p $project_name \
|
|
||||||
-f installation/docker-compose-common.yml \
|
|
||||||
-f installation/docker-compose-frappe.yml \
|
|
||||||
-f installation/frappe-publish.yml \
|
|
||||||
$@
|
|
||||||
}
|
|
||||||
|
|
||||||
check_migration_complete() {
|
|
||||||
print_group Check migration
|
|
||||||
|
|
||||||
container_id=$(docker_compose_with_args ps -q frappe-python)
|
|
||||||
cmd="docker logs ${container_id} 2>&1 | grep 'Starting gunicorn' || echo ''"
|
|
||||||
worker_log=$(eval "$cmd")
|
|
||||||
INCREMENT=0
|
|
||||||
|
|
||||||
while [[ ${worker_log} != *"Starting gunicorn"* && ${INCREMENT} -lt 120 ]]; do
|
|
||||||
sleep 3
|
|
||||||
((INCREMENT = INCREMENT + 1))
|
|
||||||
echo "Wait for migration to complete..."
|
|
||||||
worker_log=$(eval "$cmd")
|
|
||||||
if [[ ${worker_log} != *"Starting gunicorn"* && ${INCREMENT} -eq 120 ]]; then
|
|
||||||
echo Migration timeout
|
|
||||||
docker logs "${container_id}"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
echo Migration Log
|
|
||||||
docker logs "${container_id}"
|
|
||||||
}
|
|
||||||
|
|
||||||
check_health() {
|
|
||||||
print_group Loop health check
|
|
||||||
|
|
||||||
docker run --name frappe_doctor \
|
|
||||||
-v "${project_name}_sites-vol:/home/frappe/frappe-bench/sites" \
|
|
||||||
--network "${project_name}_default" \
|
|
||||||
frappe/frappe-worker:edge doctor || true
|
|
||||||
|
|
||||||
cmd='docker logs frappe_doctor | grep "Health check successful" || echo ""'
|
|
||||||
doctor_log=$(eval "$cmd")
|
|
||||||
INCREMENT=0
|
|
||||||
|
|
||||||
while [[ -z "${doctor_log}" && ${INCREMENT} -lt 60 ]]; do
|
|
||||||
sleep 1
|
|
||||||
((INCREMENT = INCREMENT + 1))
|
|
||||||
container=$(docker start frappe_doctor)
|
|
||||||
echo "Restarting ${container}..."
|
|
||||||
doctor_log=$(eval "$cmd")
|
|
||||||
|
|
||||||
if [[ ${INCREMENT} -eq 60 ]]; then
|
|
||||||
docker logs "${container}"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
# Initial group
|
# Initial group
|
||||||
echo ::group::Setup .env
|
echo ::group::Setup .env
|
||||||
cp env-example .env
|
cp env-example .env
|
||||||
|
@ -24,7 +24,6 @@ FRAPPE_VERSION=$FRAPPE_VERSION ERPNEXT_VERSION="test" \
|
|||||||
-f installation/erpnext-publish.yml \
|
-f installation/erpnext-publish.yml \
|
||||||
up -d
|
up -d
|
||||||
|
|
||||||
docker restart test_erpnext_fix-vol-permissions_1 test_erpnext_erpnext-nginx_1
|
|
||||||
print_group Create site
|
print_group Create site
|
||||||
docker run \
|
docker run \
|
||||||
--rm \
|
--rm \
|
||||||
@ -34,5 +33,10 @@ docker run \
|
|||||||
--network ${project_name}_default \
|
--network ${project_name}_default \
|
||||||
frappe/erpnext-worker:test new
|
frappe/erpnext-worker:test new
|
||||||
|
|
||||||
|
docker restart ${project_name}_erpnext-nginx_1
|
||||||
|
docker restart ${project_name}_fix-vol-permissions_1
|
||||||
|
|
||||||
|
check_health
|
||||||
|
|
||||||
ping_site
|
ping_site
|
||||||
rm .env
|
rm .env
|
||||||
|
Loading…
Reference in New Issue
Block a user