3
0
mirror of https://github.com/rvalitov/zabbix-php-fpm.git synced 2023-11-05 03:30:27 +01:00
zabbix-php-fpm/tests/all.sh

338 lines
11 KiB
Bash
Raw Normal View History

#!/bin/bash
#Ramil Valitov ramilvalitov@gmail.com
#https://github.com/rvalitov/zabbix-php-fpm
#This script is used for testing
2020-06-29 00:37:20 +02:00
MAX_POOLS=3
MAX_PORTS=3
2020-06-29 11:42:42 +02:00
MIN_PORT=9000
2020-07-06 23:50:36 +02:00
TEST_SOCKET=""
2020-06-29 11:42:42 +02:00
copyPool() {
ORIGINAL_FILE=$1
POOL_NAME=$2
POOL_SOCKET=$3
POOL_TYPE=$4
POOL_DIR=$(dirname "${ORIGINAL_FILE}")
PHP_VERSION=$(echo "$POOL_DIR" | grep -oP "(\d\.\d)")
NEW_POOL_FILE="$POOL_DIR/${POOL_NAME}.conf"
sudo cp "$ORIGINAL_FILE" "$NEW_POOL_FILE"
#Add status path
sudo sed -i 's#;pm.status_path.*#pm.status_path = /php-fpm-status#' "$NEW_POOL_FILE"
#Set pool manager
sudo sed -i "s#pm = dynamic#pm = $POOL_TYPE#" "$NEW_POOL_FILE"
#Socket
sudo sed -i "s#listen =.*#listen = $POOL_SOCKET#" "$NEW_POOL_FILE"
#Pool name
sudo sed -i "s#\[www\]#[$POOL_NAME]#" "$NEW_POOL_FILE"
}
2020-06-29 00:37:20 +02:00
setupPool() {
POOL_FILE=$1
POOL_DIR=$(dirname "${POOL_FILE}")
PHP_VERSION=$(echo "$POOL_DIR" | grep -oP "(\d\.\d)")
2020-06-29 00:37:20 +02:00
#Delete all active pools except www.conf:
2020-06-29 19:20:17 +02:00
sudo find "$POOL_DIR" -name '*.conf' -type f -not -name 'www.conf' -exec rm -rf {} \;
2020-06-29 00:37:20 +02:00
2020-06-29 11:42:42 +02:00
#Create new socket pools
for ((c = 1; c <= MAX_POOLS; c++)); do
2020-07-06 22:08:12 +02:00
POOL_NAME="static$c"
2020-06-29 11:42:42 +02:00
POOL_SOCKET="/run/php/php${PHP_VERSION}-fpm-${POOL_NAME}.sock"
copyPool "$POOL_FILE" "$POOL_NAME" "$POOL_SOCKET" "static"
2020-07-06 23:50:36 +02:00
if [[ -z $TEST_SOCKET ]]; then
TEST_SOCKET="$POOL_SOCKET"
fi
done
2020-07-06 22:08:12 +02:00
for ((c = 1; c <= MAX_POOLS; c++)); do
POOL_NAME="dynamic$c"
POOL_SOCKET="/run/php/php${PHP_VERSION}-fpm-${POOL_NAME}.sock"
copyPool "$POOL_FILE" "$POOL_NAME" "$POOL_SOCKET" "dynamic"
done
for ((c = 1; c <= MAX_POOLS; c++)); do
POOL_NAME="ondemand$c"
POOL_SOCKET="/run/php/php${PHP_VERSION}-fpm-${POOL_NAME}.sock"
copyPool "$POOL_FILE" "$POOL_NAME" "$POOL_SOCKET" "ondemand"
done
2020-06-29 11:42:42 +02:00
#Create TCP port based pools
#Division on 1 is required to convert from float to integer
2020-06-29 11:42:42 +02:00
START_PORT=$(echo "($MIN_PORT + $PHP_VERSION * 100 + 1)/1" | bc)
for ((c = 1; c <= MAX_PORTS; c++)); do
2020-06-29 11:42:42 +02:00
POOL_NAME="port$c"
POOL_PORT=$(echo "($START_PORT + $c)/1" | bc)
2020-06-29 11:42:42 +02:00
copyPool "$POOL_FILE" "$POOL_NAME" "$POOL_PORT" "static"
done
2020-06-29 11:42:42 +02:00
#Create TCP IPv4 localhost pool
POOL_NAME="localhost"
POOL_PORT=$(echo "($MIN_PORT + $PHP_VERSION * 100)/1" | bc)
POOL_SOCKET="127.0.0.1:$POOL_PORT"
copyPool "$POOL_FILE" "$POOL_NAME" "$POOL_SOCKET" "static"
sudo service "php${PHP_VERSION}-fpm" restart
}
2020-06-29 00:37:20 +02:00
setupPools() {
PHP_LIST=$(find /etc/php/ -name 'www.conf' -type f)
while IFS= read -r pool; do
if [[ -n $pool ]]; then
setupPool "$pool"
fi
done <<<"$PHP_LIST"
}
2020-06-29 00:44:32 +02:00
getNumberOfPHPVersions() {
PHP_COUNT=$(find /etc/php/ -name 'www.conf' -type f | wc -l)
echo "$PHP_COUNT"
}
getAnyPort() {
PHP_PORT=$(sudo netstat -tulpn | grep -F "LISTEN" | grep -F "php-fpm" | head -n1 | awk '{print $4}' | rev | cut -d: -f1 | rev)
assertNotNull "Failed to get PHP port" "$PHP_PORT"
echo "$PHP_PORT"
}
oneTimeSetUp() {
echo "Started job $TRAVIS_JOB_NAME"
2020-06-29 14:28:33 +02:00
echo "Host info:"
nslookup localhost
sudo ifconfig
sudo cat /etc/hosts
echo "Copying Zabbix files..."
#Install files:
sudo cp "$TRAVIS_BUILD_DIR/zabbix/zabbix_php_fpm_discovery.sh" "/etc/zabbix"
sudo cp "$TRAVIS_BUILD_DIR/zabbix/zabbix_php_fpm_status.sh" "/etc/zabbix"
sudo cp "$TRAVIS_BUILD_DIR/zabbix/userparameter_php_fpm.conf" "$(find /etc/zabbix/ -name 'zabbix_agentd*.d' -type d | head -n1)"
sudo chmod +x /etc/zabbix/zabbix_php_fpm_discovery.sh
sudo chmod +x /etc/zabbix/zabbix_php_fpm_status.sh
#Configure Zabbix:
echo 'zabbix ALL=NOPASSWD: /etc/zabbix/zabbix_php_fpm_discovery.sh,/etc/zabbix/zabbix_php_fpm_status.sh' | sudo EDITOR='tee -a' visudo
sudo service zabbix-agent restart
echo "Setup PHP-FPM..."
#Setup PHP-FPM pools:
2020-06-29 00:37:20 +02:00
setupPools
echo "All done, starting tests..."
}
testZabbixGetInstalled() {
ZABBIX_GET=$(type -P zabbix_get)
assertNotNull "Utility zabbix-get not installed" "$ZABBIX_GET"
}
testZabbixAgentVersion() {
#Example: 4.4
REQUESTED_VERSION=$(echo "$TRAVIS_JOB_NAME" | grep -i -F "zabbix" | head -n1 | cut -d "@" -f1 | cut -d " " -f2)
INSTALLED_VERSION=$(zabbix_agentd -V | grep -F "zabbix" | head -n1 | rev | cut -d " " -f1 | rev | cut -d "." -f1,2)
assertSame "Requested version $REQUESTED_VERSION and installed version $INSTALLED_VERSION of Zabbix agent do not match" "$REQUESTED_VERSION" "$INSTALLED_VERSION"
}
testZabbixGetVersion() {
#Example: 4.4
REQUESTED_VERSION=$(echo "$TRAVIS_JOB_NAME" | grep -i -F "zabbix" | head -n1 | cut -d "@" -f1 | cut -d " " -f2)
INSTALLED_VERSION=$(zabbix_get -V | grep -F "zabbix" | head -n1 | rev | cut -d " " -f1 | rev | cut -d "." -f1,2)
assertSame "Requested version $REQUESTED_VERSION and installed version $INSTALLED_VERSION of zabbix_get do not match" "$REQUESTED_VERSION" "$INSTALLED_VERSION"
}
testPHPIsRunning() {
IS_OK=$(sudo ps ax | grep -F "php-fpm: pool " | grep -F -v "grep" | head -n1)
assertNotNull "No running PHP-FPM instances found" "$IS_OK"
}
testStatusScriptSocket() {
#Make the test:
2020-07-06 23:50:36 +02:00
DATA=$(sudo -u zabbix sudo "/etc/zabbix/zabbix_php_fpm_status.sh" "$TEST_SOCKET" "/php-fpm-status")
IS_OK=$(echo "$DATA" | grep -F '{"pool":"')
assertNotNull "Failed to get status from pool $PHP_POOL: $DATA" "$IS_OK"
2020-06-29 11:42:42 +02:00
echo "Success test of $PHP_POOL"
}
testStatusScriptPort() {
PHP_PORT=$(getAnyPort)
PHP_POOL="127.0.0.1:$PHP_PORT"
#Make the test:
2020-07-06 23:29:01 +02:00
DATA=$(sudo -u zabbix sudo "/etc/zabbix/zabbix_php_fpm_status.sh" "$PHP_POOL" "/php-fpm-status")
IS_OK=$(echo "$DATA" | grep -F '{"pool":"')
assertNotNull "Failed to get status from pool $PHP_POOL: $DATA" "$IS_OK"
2020-06-29 11:42:42 +02:00
echo "Success test of $PHP_POOL"
}
testZabbixStatusSocket() {
2020-07-06 23:50:36 +02:00
DATA=$(zabbix_get -s 127.0.0.1 -p 10050 -k php-fpm.status["$TEST_SOCKET","/php-fpm-status"])
IS_OK=$(echo "$DATA" | grep -F '{"pool":"')
assertNotNull "Failed to get status from pool $PHP_POOL: $DATA" "$IS_OK"
2020-06-29 11:42:42 +02:00
echo "Success test of $PHP_POOL"
}
testZabbixStatusPort() {
PHP_PORT=$(getAnyPort)
PHP_POOL="127.0.0.1:$PHP_PORT"
DATA=$(zabbix_get -s 127.0.0.1 -p 10050 -k php-fpm.status["$PHP_POOL","/php-fpm-status"])
IS_OK=$(echo "$DATA" | grep -F '{"pool":"')
assertNotNull "Failed to get status from pool $PHP_POOL: $DATA" "$IS_OK"
2020-06-29 11:42:42 +02:00
echo "Success test of $PHP_POOL"
}
testDiscoverScriptReturnsData() {
2020-07-06 23:29:01 +02:00
DATA=$(sudo -u zabbix sudo "/etc/zabbix/zabbix_php_fpm_discovery.sh" "/php-fpm-status")
IS_OK=$(echo "$DATA" | grep -F '{"data":[{"{#POOLNAME}"')
assertNotNull "Discover script failed: $DATA" "$IS_OK"
}
2020-06-29 01:16:36 +02:00
testDiscoverScriptDebug() {
2020-07-07 00:31:17 +02:00
DATA=$(sudo -u zabbix sudo "/etc/zabbix/zabbix_php_fpm_discovery.sh" "debug" "nosleep" "/php-fpm-status")
2020-07-06 23:56:13 +02:00
NUMBER_OF_ERRORS=$(echo "$DATA" | grep -o -F 'Error:' | wc -l)
PHP_COUNT=$(getNumberOfPHPVersions)
2020-07-07 04:25:12 +02:00
if [[ $PHP_COUNT != "$NUMBER_OF_ERRORS" ]]; then
2020-07-07 00:13:01 +02:00
ERRORS_LIST=$(echo "$DATA" | grep -F 'Error:')
echo "Errors list:"
echo "$ERRORS_LIST"
echo "Full output:"
echo "$DATA"
fi
assertEquals "Discover script errors mismatch" "$PHP_COUNT" "$NUMBER_OF_ERRORS"
2020-06-29 01:16:36 +02:00
}
2020-06-29 00:18:44 +02:00
testZabbixDiscoverReturnsData() {
DATA=$(zabbix_get -s 127.0.0.1 -p 10050 -k php-fpm.discover["/php-fpm-status"])
IS_OK=$(echo "$DATA" | grep -F '{"data":[{"{#POOLNAME}"')
assertNotNull "Discover script failed: $DATA" "$IS_OK"
}
2020-07-07 04:25:12 +02:00
function discoverAll() {
DATA_OLD=$1
DATA_COUNT=$2
2020-07-07 00:31:17 +02:00
2020-07-07 04:25:12 +02:00
if [[ -z $DATA_COUNT ]]; then
DATA_COUNT=0
fi
DATA=$(zabbix_get -s 127.0.0.1 -p 10050 -k php-fpm.discover["/php-fpm-status"])
if [[ $DATA_OLD == "$DATA" ]]; then
echo "$DATA"
return 0
else
DATA_COUNT=$(echo "$DATA_COUNT + 1" | bc)
if [[ $DATA_COUNT -gt 10 ]]; then
return 1
fi
discoverAll "$DATA" "$DATA_COUNT"
fi
}
testZabbixDiscoverNumberOfStaticPools() {
DATA=$(discoverAll)
STATUS=$?
assertEquals "Failed to discover all data" "0" "$STATUS"
2020-07-07 00:31:17 +02:00
2020-07-06 22:08:12 +02:00
NUMBER_OF_POOLS=$(echo "$DATA" | grep -o -F '{"{#POOLNAME}":"static' | wc -l)
PHP_COUNT=$(getNumberOfPHPVersions)
2020-07-06 22:12:47 +02:00
POOLS_BY_DESIGN=$(echo "$PHP_COUNT * $MAX_POOLS" | bc)
assertEquals "Number of pools mismatch" "$POOLS_BY_DESIGN" "$NUMBER_OF_POOLS"
2020-07-06 22:08:12 +02:00
}
testZabbixDiscoverNumberOfDynamicPools() {
2020-07-07 04:25:12 +02:00
DATA=$(discoverAll)
STATUS=$?
assertEquals "Failed to discover all data" "0" "$STATUS"
2020-07-07 00:31:17 +02:00
2020-07-06 22:08:12 +02:00
NUMBER_OF_POOLS=$(echo "$DATA" | grep -o -F '{"{#POOLNAME}":"dynamic' | wc -l)
PHP_COUNT=$(getNumberOfPHPVersions)
2020-07-06 22:12:47 +02:00
POOLS_BY_DESIGN=$(echo "$PHP_COUNT * $MAX_POOLS" | bc)
assertEquals "Number of pools mismatch" "$POOLS_BY_DESIGN" "$NUMBER_OF_POOLS"
2020-07-06 22:08:12 +02:00
}
2020-07-06 23:50:36 +02:00
testZabbixDiscoverNumberOfOndemandPoolsCold() {
2020-07-07 04:25:12 +02:00
DATA=$(discoverAll)
STATUS=$?
assertEquals "Failed to discover all data" "0" "$STATUS"
2020-07-07 00:31:17 +02:00
2020-07-06 23:50:36 +02:00
NUMBER_OF_POOLS=$(echo "$DATA" | grep -o -F '{"{#POOLNAME}":"ondemand' | wc -l)
#If the pools are not started then we have 0 here:
assertEquals "Number of pools mismatch" "0" "$NUMBER_OF_POOLS"
}
testZabbixDiscoverNumberOfOndemandPoolsHot() {
# We must start all the pools
2020-07-07 00:18:14 +02:00
POOL_URL="/php-fpm-status"
2020-07-07 00:05:11 +02:00
PHP_COUNT=$(getNumberOfPHPVersions)
PHP_LIST=$(find /etc/php/ -name 'www.conf' -type f)
while IFS= read -r pool; do
if [[ -n $pool ]]; then
POOL_DIR=$(dirname "$pool")
PHP_VERSION=$(echo "$POOL_DIR" | grep -oP "(\d\.\d)")
for ((c = 1; c <= MAX_POOLS; c++)); do
POOL_NAME="ondemand$c"
POOL_SOCKET="/run/php/php${PHP_VERSION}-fpm-${POOL_NAME}.sock"
SCRIPT_NAME=$POOL_SOCKET \
SCRIPT_FILENAME=$POOL_SOCKET \
QUERY_STRING=json \
REQUEST_METHOD=GET \
2020-07-07 00:18:14 +02:00
sudo cgi-fcgi -bind -connect "$POOL_URL" 2>/dev/null
2020-07-07 00:05:11 +02:00
done
fi
done <<<"$PHP_LIST"
2020-07-06 23:50:36 +02:00
2020-07-07 00:31:17 +02:00
OLD_DATA=""
DATA="1"
while
[[ $OLD_DATA != "$DATA" ]]
OLD_DATA="$DATA"
DATA=$(zabbix_get -s 127.0.0.1 -p 10050 -k php-fpm.discover["/php-fpm-status"])
do true; done
2020-07-06 22:08:12 +02:00
NUMBER_OF_POOLS=$(echo "$DATA" | grep -o -F '{"{#POOLNAME}":"ondemand' | wc -l)
2020-06-29 00:44:32 +02:00
PHP_COUNT=$(getNumberOfPHPVersions)
2020-07-06 22:12:47 +02:00
POOLS_BY_DESIGN=$(echo "$PHP_COUNT * $MAX_POOLS" | bc)
assertEquals "Number of pools mismatch" "$POOLS_BY_DESIGN" "$NUMBER_OF_POOLS"
2020-06-29 00:44:32 +02:00
}
2020-06-29 11:42:42 +02:00
testZabbixDiscoverNumberOfIPPools() {
2020-07-07 04:25:12 +02:00
DATA=$(discoverAll)
STATUS=$?
assertEquals "Failed to discover all data" "0" "$STATUS"
2020-07-07 00:31:17 +02:00
2020-06-29 11:42:42 +02:00
NUMBER_OF_POOLS=$(echo "$DATA" | grep -o -F '{"{#POOLNAME}":"localhost",' | wc -l)
PHP_COUNT=$(getNumberOfPHPVersions)
POOLS_BY_DESIGN="$PHP_COUNT"
2020-07-06 22:12:47 +02:00
assertEquals "Number of pools mismatch" "$POOLS_BY_DESIGN" "$NUMBER_OF_POOLS"
2020-06-29 11:42:42 +02:00
}
testZabbixDiscoverNumberOfPortPools() {
2020-07-07 04:25:12 +02:00
DATA=$(discoverAll)
STATUS=$?
assertEquals "Failed to discover all data" "0" "$STATUS"
2020-07-07 00:31:17 +02:00
2020-07-06 22:12:47 +02:00
NUMBER_OF_POOLS=$(echo "$DATA" | grep -o -F '{"{#POOLNAME}":"port' | wc -l)
2020-06-29 00:44:32 +02:00
PHP_COUNT=$(getNumberOfPHPVersions)
2020-07-06 22:12:47 +02:00
POOLS_BY_DESIGN=$(echo "$PHP_COUNT * $MAX_POOLS" | bc)
assertEquals "Number of pools mismatch" "$POOLS_BY_DESIGN" "$NUMBER_OF_POOLS"
2020-06-29 00:44:32 +02:00
}
2020-07-05 23:18:23 +02:00
#This test should be last in Zabbix tests
2020-06-29 18:06:35 +02:00
testZabbixDiscoverTimeout() {
#Create lots of pools
MAX_POOLS=100
MAX_PORTS=100
setupPools
testZabbixDiscoverReturnsData
}
# Load shUnit2.
. shunit2