Merge pull request #6596 from zmstone/ci-test-specific-package

build: ci tests.sh test specific package
This commit is contained in:
Zaiming (Stone) Shi 2021-12-31 22:13:48 +01:00 committed by GitHub
commit 9ab9a6ebad
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 138 additions and 98 deletions

View File

@ -1,5 +1,23 @@
#!/bin/bash #!/usr/bin/env bash
## This script tests built package start/stop
## Accept 2 args PACKAGE_NAME and PACKAGE_TYPE
set -x -e -u set -x -e -u
if [ -z "${1:-}" ]; then
echo "Usage $0 <PACKAGE_NAME> zip|pkg"
exit 1
fi
if [ "${2:-}" != 'zip' ] && [ "${2:-}" != 'pkg' ]; then
echo "Usage $0 <PACKAGE_NAME> zip|pkg"
exit 1
fi
PACKAGE_NAME="${1}"
PACKAGE_TYPE="${2}"
export CODE_PATH=${CODE_PATH:-"/emqx"} export CODE_PATH=${CODE_PATH:-"/emqx"}
export EMQX_NAME=${EMQX_NAME:-"emqx"} export EMQX_NAME=${EMQX_NAME:-"emqx"}
export PACKAGE_PATH="${CODE_PATH}/_packages/${EMQX_NAME}" export PACKAGE_PATH="${CODE_PATH}/_packages/${EMQX_NAME}"
@ -7,6 +25,26 @@ export RELUP_PACKAGE_PATH="${CODE_PATH}/_upgrade_base"
# export EMQX_NODE_NAME="emqx-on-$(uname -m)@127.0.0.1" # export EMQX_NODE_NAME="emqx-on-$(uname -m)@127.0.0.1"
# export EMQX_NODE_COOKIE=$(date +%s%N) # export EMQX_NODE_COOKIE=$(date +%s%N)
if [ "$PACKAGE_TYPE" = 'zip' ]; then
PKG_SUFFIX="zip"
else
SYSTEM="$($CODE_PATH/scripts/get-distro.sh)"
case "${SYSTEM:-}" in
ubuntu*|debian*|raspbian*)
PKG_SUFFIX='deb'
;;
*)
PKG_SUFFIX='rpm'
;;
esac
fi
PACKAGE_FILE_NAME="${PACKAGE_NAME}.${PKG_SUFFIX}"
PACKAGE_FILE="${PACKAGE_PATH}/${PACKAGE_FILE_NAME}.${PKG_SUFFIX}"
if ! [ -f "$PACKAGE_FILE" ]; then
echo "$PACKAGE_FILE is not a file"
fi
case "$(uname -m)" in case "$(uname -m)" in
x86_64) x86_64)
ARCH='amd64' ARCH='amd64'
@ -22,7 +60,6 @@ export ARCH
emqx_prepare(){ emqx_prepare(){
mkdir -p "${PACKAGE_PATH}" mkdir -p "${PACKAGE_PATH}"
if [ ! -d "/paho-mqtt-testing" ]; then if [ ! -d "/paho-mqtt-testing" ]; then
git clone -b develop-4.0 https://github.com/emqx/paho.mqtt.testing.git /paho-mqtt-testing git clone -b develop-4.0 https://github.com/emqx/paho.mqtt.testing.git /paho-mqtt-testing
fi fi
@ -31,11 +68,9 @@ emqx_prepare(){
emqx_test(){ emqx_test(){
cd "${PACKAGE_PATH}" cd "${PACKAGE_PATH}"
local packagename="${PACKAGE_FILE_NAME}"
for var in "$PACKAGE_PATH"/"${EMQX_NAME}"-*;do case "$PKG_SUFFIX" in
case ${var##*.} in
"zip") "zip")
packagename=$(basename "${PACKAGE_PATH}/${EMQX_NAME}"-*.zip)
unzip -q "${PACKAGE_PATH}/${packagename}" unzip -q "${PACKAGE_PATH}/${packagename}"
export EMQX_ZONE__EXTERNAL__SERVER__KEEPALIVE=60 \ export EMQX_ZONE__EXTERNAL__SERVER__KEEPALIVE=60 \
EMQX_MQTT__MAX_TOPIC_ALIAS=10 EMQX_MQTT__MAX_TOPIC_ALIAS=10
@ -64,7 +99,6 @@ emqx_test(){
rm -rf "${PACKAGE_PATH}"/emqx rm -rf "${PACKAGE_PATH}"/emqx
;; ;;
"deb") "deb")
packagename=$(basename "${PACKAGE_PATH}/${EMQX_NAME}"-*.deb)
dpkg -i "${PACKAGE_PATH}/${packagename}" dpkg -i "${PACKAGE_PATH}/${packagename}"
if [ "$(dpkg -l |grep emqx |awk '{print $1}')" != "ii" ] if [ "$(dpkg -l |grep emqx |awk '{print $1}')" != "ii" ]
then then
@ -91,8 +125,6 @@ emqx_test(){
fi fi
;; ;;
"rpm") "rpm")
packagename=$(basename "${PACKAGE_PATH}/${EMQX_NAME}"-*.rpm)
if [[ "${ARCH}" == "amd64" && $(rpm -E '%{rhel}') == 7 ]] ; then if [[ "${ARCH}" == "amd64" && $(rpm -E '%{rhel}') == 7 ]] ; then
# EMQX OTP requires openssl11 to have TLS1.3 support # EMQX OTP requires openssl11 to have TLS1.3 support
yum install -y openssl11 yum install -y openssl11
@ -114,9 +146,7 @@ emqx_test(){
exit 1 exit 1
fi fi
;; ;;
esac esac
done
} }
running_test(){ running_test(){

View File

@ -318,13 +318,11 @@ jobs:
SYSTEM: ${{ matrix.os }} SYSTEM: ${{ matrix.os }}
working-directory: source working-directory: source
run: | run: |
docker run -i --rm \ ./scripts/buildx.sh \
-v $(pwd):/emqx \ --profile "${PROFILE}" \
--workdir /emqx \ --pkgtype "${PACKAGE}" \
--platform linux/$ARCH \ --arch "${ARCH}" \
ghcr.io/emqx/emqx-builder/4.4-4:$OTP-$SYSTEM \ --builder "ghcr.io/emqx/emqx-builder/4.4-4:${OTP}-${SYSTEM}"
bash -euc "make ${PROFILE}-${PACKAGE} || cat rebar3.crashdump; \
EMQX_NAME=$PROFILE && .ci/build_packages/tests.sh"
- name: create sha256 - name: create sha256
working-directory: source working-directory: source
env: env:

View File

@ -52,8 +52,11 @@ jobs:
path: ./rebar3.crashdump path: ./rebar3.crashdump
- name: packages test - name: packages test
run: | run: |
export CODE_PATH=$GITHUB_WORKSPACE PKG_VSN="$(./pkg-vsn.sh)"
.ci/build_packages/tests.sh PKG_NAME="${EMQX_NAME}-${PKG_VSN}-otp${{ matrix.erl_otp }}-${{ matrix.os }}-amd64"
export CODE_PATH="$GITHUB_WORKSPACE"
.ci/build_packages/tests.sh "$PKG_NAME" zip
.ci/build_packages/tests.sh "$PKG_NAME" pkg
- uses: actions/upload-artifact@v2 - uses: actions/upload-artifact@v2
with: with:
name: ${{ matrix.os }} name: ${{ matrix.os }}

View File

@ -15,11 +15,11 @@ set -euo pipefail
help() { help() {
echo echo
echo "-h|--help: To display this usage information" echo "-h|--help: To display this usage information"
echo "--pkgtype zip|pkg: Specify to build zip or deb|rpm package"
echo "--arch amd64|arm64: Target arch to build the EMQ X package for."
echo "--src_dir <SRC_DIR>: EMQ X source ode in this dir, default to PWD"
echo "--profile <PROFILE>: EMQ X profile to build, e.g. emqx, emqx-edge" echo "--profile <PROFILE>: EMQ X profile to build, e.g. emqx, emqx-edge"
echo "--builder <BUILDER>: Builder image to pull." echo "--pkgtype zip|pkg: Specify which package to build, zip for .zip and pkg for .rpm or .deb"
echo "--arch amd64|arm64: Target arch to build the EMQ X package for"
echo "--src_dir <SRC_DIR>: EMQ X source ode in this dir, default to PWD"
echo "--builder <BUILDER>: Builder image to pull"
echo " E.g. ghcr.io/emqx/emqx-builder/4.4-4:24.1.5-3-debian10" echo " E.g. ghcr.io/emqx/emqx-builder/4.4-4:24.1.5-3-debian10"
} }
@ -62,14 +62,23 @@ if [ -z "${PROFILE:-}" ] || [ -z "${PKGTYPE:-}" ] || [ -z "${BUILDER:-}" ] || [
exit 1 exit 1
fi fi
docker run --rm --privileged tonistiigi/binfmt:latest --install ${ARCH} if [ "$PKGTYPE" != 'zip' ] && [ "$PKGTYPE" != 'pkg' ]; then
echo "Bad --pkgtype option, should be zip or pkg"
exit 1
fi
cd "${SRC_DIR:-.}" cd "${SRC_DIR:-.}"
PKG_VSN="${PKG_VSN:-$(./pkg-vsn.sh)}"
OTP_VSN_SYSTEM=$(echo "$BUILDER" | cut -d ':' -f2)
PKG_NAME="${PROFILE}-${PKG_VSN}-otp${OTP_VSN_SYSTEM}-${ARCH}"
docker info
docker run --rm --privileged tonistiigi/binfmt:latest --install ${ARCH}
docker run -i --rm \ docker run -i --rm \
-v "$(pwd)":/emqx \ -v "$(pwd)":/emqx \
--workdir /emqx \ --workdir /emqx \
--platform="linux/$ARCH" \ --platform="linux/$ARCH" \
-e EMQX_NAME="$PROFILE" \ -e EMQX_NAME="$PROFILE" \
"$BUILDER" \ "$BUILDER" \
bash -euc "make ${PROFILE}-${PKGTYPE} && .ci/build_packages/tests.sh" bash -euc "make ${PROFILE}-${PKGTYPE} && .ci/build_packages/tests.sh $PKG_NAME $PKGTYPE"