emqx/scripts/pkg-tests.sh

254 lines
7.5 KiB
Bash
Executable File

#!/usr/bin/env bash
set -euo pipefail
set -x
MAKE_TARGET="${1:-}"
case "${MAKE_TARGET}" in
emqx-enterprise-*)
EMQX_NAME='emqx-enterprise'
;;
emqx-*)
EMQX_NAME='emqx'
;;
*)
echo "Usage $0 <PKG_TARGET>"
exit 1
;;
esac
case "${MAKE_TARGET}" in
*-tgz)
PACKAGE_TYPE='tgz'
;;
*-pkg)
PACKAGE_TYPE='pkg'
;;
*)
echo "Unknown package type ${1}"
exit 2
;;
esac
case "${MAKE_TARGET}" in
*elixir*)
IS_ELIXIR='yes'
;;
*)
IS_ELIXIR='no'
;;
esac
export DEBUG=1
export CODE_PATH=${CODE_PATH:-"/emqx"}
export SCRIPTS="${CODE_PATH}/scripts"
export EMQX_NAME
export PACKAGE_PATH="${CODE_PATH}/_packages/${EMQX_NAME}"
export RELUP_PACKAGE_PATH="${CODE_PATH}/_upgrade_base"
export PAHO_MQTT_TESTING_PATH="${PAHO_MQTT_TESTING_PATH:-/paho-mqtt-testing}"
SYSTEM="$("$SCRIPTS"/get-distro.sh)"
if [ "$PACKAGE_TYPE" = 'tgz' ]; then
PKG_SUFFIX="tar.gz"
else
case "${SYSTEM:-}" in
ubuntu*|debian*|raspbian*)
PKG_SUFFIX='deb'
;;
*)
PKG_SUFFIX='rpm'
;;
esac
fi
PACKAGE_VERSION="$("$CODE_PATH"/pkg-vsn.sh "${EMQX_NAME}")"
PACKAGE_VERSION_LONG="$("$CODE_PATH"/pkg-vsn.sh "${EMQX_NAME}" --long --elixir "${IS_ELIXIR}")"
PACKAGE_NAME="${EMQX_NAME}-${PACKAGE_VERSION_LONG}"
PACKAGE_FILE_NAME="${PACKAGE_FILE_NAME:-${PACKAGE_NAME}.${PKG_SUFFIX}}"
PACKAGE_FILE="${PACKAGE_PATH}/${PACKAGE_FILE_NAME}"
if ! [ -f "$PACKAGE_FILE" ]; then
echo "$PACKAGE_FILE is not a file"
exit 1
fi
emqx_prepare(){
mkdir -p "${PACKAGE_PATH}"
if [ ! -d "${PAHO_MQTT_TESTING_PATH}" ]; then
git clone -b develop-4.0 https://github.com/emqx/paho.mqtt.testing.git "${PAHO_MQTT_TESTING_PATH}"
fi
# Debian 12 complains if we don't use venv
case "${SYSTEM:-}" in
debian12)
apt-get update -y && apt-get install -y virtualenv
virtualenv venv
# https://www.shellcheck.net/wiki/SC1091
# shellcheck source=/dev/null
source ./venv/bin/activate
;;
*)
;;
esac
pip3 install pytest
}
emqx_test(){
cd "${PACKAGE_PATH}"
local packagename="${PACKAGE_FILE_NAME}"
case "$PKG_SUFFIX" in
"tar.gz")
mkdir -p "${PACKAGE_PATH}/emqx"
tar -C "${PACKAGE_PATH}/emqx" -zxf "${PACKAGE_PATH}/${packagename}"
export EMQX_ZONES__DEFAULT__MQTT__SERVER_KEEPALIVE=60
export EMQX_MQTT__MAX_TOPIC_ALIAS=10
export EMQX_LOG__CONSOLE_HANDLER__LEVEL=debug
export EMQX_LOG__FILE_HANDLERS__DEFAULT__LEVEL=debug
# if [[ $(arch) == *arm* || $(arch) == aarch64 ]]; then
# export EMQX_LISTENERS__QUIC__DEFAULT__ENABLED=false
# fi
# sed -i '/emqx_telemetry/d' "${PACKAGE_PATH}"/emqx/data/loaded_plugins
run_test "${PACKAGE_PATH}/emqx/bin" "${PACKAGE_PATH}/emqx/log" "${PACKAGE_PATH}/emqx/releases/emqx_vars"
rm -rf "${PACKAGE_PATH}"/emqx
;;
"deb")
dpkg -i "${PACKAGE_PATH}/${packagename}"
if [ "$(dpkg -l | grep ${EMQX_NAME} | awk '{print $1}')" != "ii" ]
then
echo "package install error"
exit 1
fi
run_test "/usr/bin" "/var/log/emqx" "$(dpkg -L ${EMQX_NAME} | grep emqx_vars)"
dpkg -r "${EMQX_NAME}"
if [ "$(dpkg -l | grep ${EMQX_NAME} | awk '{print $1}')" != "rc" ]
then
echo "package remove error"
exit 1
fi
dpkg -P "${EMQX_NAME}"
if dpkg -l |grep -q emqx
then
echo "package uninstall error"
exit 1
fi
;;
"rpm")
# yum wants python2
case "${SYSTEM:-}" in
"el8")
# el8 is fine with python3
true
;;
"el9")
# el9 is fine with python3
true
;;
*)
alternatives --list | grep python && alternatives --set python /usr/bin/python2
;;
esac
YUM_RES=$(yum install -y "${PACKAGE_PATH}/${packagename}"| tee /dev/null)
if [[ $YUM_RES =~ "Failed" ]]; then
echo "yum install failed"
exit 1
fi
alternatives --list | grep python && alternatives --set python /usr/bin/python3
if ! rpm -q "${EMQX_NAME}" | grep -q "${EMQX_NAME}"; then
echo "package install error"
exit 1
fi
run_test "/usr/bin" "/var/log/emqx" "$(rpm -ql ${EMQX_NAME} | grep emqx_vars)"
rpm -e "${EMQX_NAME}"
if [ "$(rpm -q ${EMQX_NAME})" != "package ${EMQX_NAME} is not installed" ];then
echo "package uninstall error"
exit 1
fi
;;
esac
}
run_test(){
local bin_dir="$1"
local log_dir="$2"
local emqx_env_vars="$3"
# sed -i '/emqx_telemetry/d' /var/lib/emqx/loaded_plugins
if [ -f "$emqx_env_vars" ];
then
tee -a "$emqx_env_vars" <<EOF
export EMQX_ZONES__DEFAULT__MQTT__SERVER_KEEPALIVE=60
export EMQX_MQTT__MAX_TOPIC_ALIAS=10
export EMQX_LOG__CONSOLE_HANDLER__LEVEL=debug
export EMQX_LOG__FILE_HANDLERS__DEFAULT__LEVEL=debug
EOF
## for ARM, due to CI env issue, skip start of quic listener for the moment
# [[ $(arch) == *arm* || $(arch) == aarch64 ]] && tee -a "$emqx_env_vars" <<EOF
# export EMQX_LISTENERS__QUIC__DEFAULT__ENABLED=false
# EOF
else
echo "Error: cannot locate emqx_vars"
exit 1
fi
echo "running ${packagename} start"
if ! "${bin_dir}/emqx" 'start'; then
echo "ERROR: failed_to_start_emqx"
cat "${log_dir}/erlang.log.1" || true
cat "${log_dir}/emqx.log.1" || true
exit 1
fi
"$SCRIPTS/test/emqx-smoke-test.sh" 127.0.0.1 18083
pytest -v "${PAHO_MQTT_TESTING_PATH}"/interoperability/test_client/V5/test_connect.py::test_basic
"${bin_dir}/emqx" ping
echo "running ${packagename} stop"
if ! "${bin_dir}/emqx" 'stop'; then
echo "ERROR: failed_to_stop_emqx_with_the_stop_command"
cat "${log_dir}/erlang.log.1" || true
cat "${log_dir}/emqx.log.1" || true
exit 1
fi
}
relup_test(){
if [ ! -d "${RELUP_PACKAGE_PATH}" ]; then
echo "WARNING: ${RELUP_PACKAGE_PATH} is not a dir, skipped relup test!"
return 0
fi
cd "${RELUP_PACKAGE_PATH}"
local pattern
pattern="$EMQX_NAME-$("$CODE_PATH"/pkg-vsn.sh "${EMQX_NAME}" --long --vsn_matcher)"
while read -r pkg; do
packagename=$(basename "${pkg}")
mkdir -p emqx
tar -C emqx -zxf "$packagename"
if ! ./emqx/bin/emqx start; then
cat emqx/log/erlang.log.1 || true
cat emqx/log/emqx.log.1 || true
exit 1
fi
./emqx/bin/emqx_ctl status
./emqx/bin/emqx versions
cp "${PACKAGE_PATH}/${PACKAGE_NAME}.tar.gz" ./emqx/releases/
./emqx/bin/emqx install "${PACKAGE_VERSION}"
[ "$(./emqx/bin/emqx versions | grep permanent | awk '{print $2}')" = "${PACKAGE_VERSION}" ] || exit 1
./emqx/bin/emqx_ctl status
./emqx/bin/emqx stop
rm -rf emqx
done < <(find . -maxdepth 1 -name "${pattern}.tar.gz")
}
emqx_prepare
emqx_test
if [ "$IS_ELIXIR" = 'yes' ]; then
echo "WARNING: skipped relup test for elixir"
else
relup_test
fi