devilbox/.tests/intra-tests/php-xdebug.sh

129 lines
3.6 KiB
Bash
Raw Normal View History

2018-12-16 15:10:39 +00:00
#!/usr/bin/env bash
set -e
set -u
set -o pipefail
DISABLED_VERSIONS=("7.4" "8.0")
2018-12-16 15:10:39 +00:00
#
# NOTE: Parsing curl to tac to circumnvent "failed writing body"
# https://stackoverflow.com/questions/16703647/why-curl-return-and-error-23-failed-writing-body
#
###
### Fetch PHP version
2018-12-16 15:10:39 +00:00
###
printf "[TEST] Get PHP version"
2018-12-16 15:10:39 +00:00
# 1st Try
2018-12-18 13:47:09 +00:00
if ! PHP_VERSION="$( curl -sS localhost/index.php | tac | tac | grep -Eo 'PHP.*?\([.0-9]+' | grep -Eo '\([.0-9]+' | grep -Eo '[0-9]+\.[0-9]+' )"; then
2018-12-16 15:10:39 +00:00
# 2nd Try
sleep 1
2018-12-18 13:47:09 +00:00
if ! PHP_VERSION="$( curl -sS localhost/index.php | tac | tac | grep -Eo 'PHP.*?\([.0-9]+' | grep -Eo '\([.0-9]+' | grep -Eo '[0-9]+\.[0-9]+' )"; then
2018-12-16 15:10:39 +00:00
# 3rd Try
sleep 1
2018-12-18 13:47:09 +00:00
if ! PHP_VERSION="$( curl -sS localhost/index.php | tac | tac | grep -Eo 'PHP.*?\([.0-9]+' | grep -Eo '\([.0-9]+' | grep -Eo '[0-9]+\.[0-9]+' )"; then
printf "\r[FAIL] Get PHP version\n"
2018-12-18 13:47:09 +00:00
curl -sS localhost/index.php | tac | tac | grep -Eo 'PHP.*?\([.0-9]+' || true
2018-12-16 15:10:39 +00:00
exit 1
else
printf "\r[OK] Get PHP version (3 rounds): %s\n" "${PHP_VERSION}"
2018-12-16 15:10:39 +00:00
fi
else
printf "\r[OK] Get PHP version (2 rounds): %s\n" "${PHP_VERSION}"
2018-12-16 15:10:39 +00:00
fi
else
printf "\r[OK] Get PHP version (1 round): %s\n" "${PHP_VERSION}"
2018-12-16 15:10:39 +00:00
fi
###
### Ensure only to check against desired versions
###
### https://stackoverflow.com/a/15394738
2018-12-16 15:10:39 +00:00
###
if [[ ${DISABLED_VERSIONS[*]} =~ ${PHP_VERSION} ]]; then
printf "[SKIP] Skipping all checks for PHP ${PHP_VERSION}\n"
exit 0
fi
2018-12-16 15:10:39 +00:00
###
### Xdebug available
###
printf "[TEST] Xdebug available"
# 1st Try
if ! curl -sS localhost/info_php.php | tac | tac | grep -q 'xdebug\.remote_enable'; then
# 2nd Try
sleep 1
if ! curl -sS localhost/info_php.php | tac | tac | grep -q 'xdebug\.remote_enable'; then
# 3rd Try
sleep 1
if ! curl -sS localhost/info_php.php | tac | tac | grep -q 'xdebug\.remote_enable'; then
printf "\r[FAIL] Xdebug available\n"
curl -sS localhost/info_php.php | tac | tac | grep 'xdebug' || true
exit 1
else
printf "\r[OK] Xdebug available (3 rounds)\n"
fi
else
printf "\r[OK] Xdebug available (2 rounds)\n"
fi
else
printf "\r[OK] Xdebug available (1 round)\n"
fi
###
### Xdebug default disabled
###
printf "[TEST] Xdebug default disabled"
# 1st Try
if ! curl -sS localhost/info_php.php | tac | tac | grep 'xdebug\.remote_enable' | grep -Eq 'Off.+Off'; then
# 2nd Try
sleep 1
2018-12-16 15:10:39 +00:00
if ! curl -sS localhost/info_php.php | tac | tac | grep 'xdebug\.remote_enable' | grep -Eq 'Off.+Off'; then
# 3rd Try
2018-12-16 15:10:39 +00:00
sleep 1
if ! curl -sS localhost/info_php.php | tac | tac | grep 'xdebug\.remote_enable' | grep -Eq 'Off.+Off'; then
printf "\r[FAIL] Xdebug default disabled\n"
curl -sS localhost/info_php.php | tac | tac | grep 'xdebug' || true
exit 1
2018-12-16 15:10:39 +00:00
else
printf "\r[OK] Xdebug default disabled (3 rounds)\n"
2018-12-16 15:10:39 +00:00
fi
else
printf "\r[OK] Xdebug default disabled (2 rounds)\n"
2018-12-16 15:10:39 +00:00
fi
else
printf "\r[OK] Xdebug default disabled (1 round)\n"
fi
###
### Xdebug autostart disabled
###
printf "[TEST] Xdebug autostart disabled"
# 1st Try
if ! curl -sS localhost/info_php.php | tac | tac | grep 'xdebug\.remote_autostart' | grep -Eq 'Off.+Off'; then
# 2nd Try
sleep 1
2018-12-18 10:51:12 +00:00
if ! curl -sS localhost/info_php.php | tac | tac | grep 'xdebug\.remote_autostart' | grep -Eq 'Off.+Off'; then
# 3rd Try
2018-12-18 10:51:12 +00:00
sleep 1
if ! curl -sS localhost/info_php.php | tac | tac | grep 'xdebug\.remote_autostart' | grep -Eq 'Off.+Off'; then
printf "\r[FAIL] Xdebug autostart disabled\n"
curl -sS localhost/info_php.php | tac | tac | grep 'xdebug' || true
exit 1
2018-12-18 10:51:12 +00:00
else
printf "\r[OK] Xdebug autostart disabled (3 rounds)\n"
2018-12-18 10:51:12 +00:00
fi
else
printf "\r[OK] Xdebug autostart disabled (2 rounds)\n"
2018-12-18 10:51:12 +00:00
fi
else
printf "\r[OK] Xdebug autostart disabled (1 round)\n"
2018-12-16 15:10:39 +00:00
fi