#!/bin/bash # # Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you under the Apache License, Version 2.0 (the # "License"); you may not use this file except in compliance # with the License. You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, # software distributed under the License is distributed on an # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY # KIND, either express or implied. See the License for the # specific language governing permissions and limitations # under the License. # # Run the federation system tests. source ./test_env.sh MODULENAME=federation_sys # FIXME aconway 2011-12-15: Disable cluster-related tests on the qpid-3603 # branch. See comment in cluster.mk for more details. # # # Test for clustering # ps -u root | grep 'aisexec\|corosync' > /dev/null # if (( $? == 0 )); then # CLUSTERING_ENABLED=1 # else # echo "WARNING: No clustering detected; tests using it will be ignored." # fi # Test for long test if [[ "$1" == "LONG_TEST" ]]; then USE_LONG_TEST=1 shift # get rid of this param so it is not treated as a test name fi trap stop_brokers INT TERM QUIT SKIPTESTS="-i federation_sys.E_* -i federation_sys.F_* -i federation_sys.G_* -i federation_sys.H_*" if [ -z ${USE_LONG_TEST} ]; then SKIPTESTS="-i federation_sys.A_Long* -i federation_sys.B_Long* ${SKIPTESTS}" fi echo "WARNING: Tests using persistence will be ignored." if [ -z ${CLUSTERING_ENABLED} ]; then SKIPTESTS="${SKIPTESTS} -i federation_sys.C_* -i federation_sys.D_*" elif [ -z ${USE_LONG_TEST} ]; then SKIPTESTS="${SKIPTESTS} -i federation_sys.C_Long* -i federation_sys.D_Long*" fi start_brokers() { start_broker() { ${QPIDD_EXEC} --daemon --port 0 --auth no --no-data-dir $1 > qpidd.port PORT=`cat qpidd.port` eval "$2=${PORT}" } start_broker "" LOCAL_PORT start_broker "" REMOTE_PORT if [ -n "${CLUSTERING_ENABLED}" ]; then start_broker "--load-module ${CLUSTER_LIB} --cluster-name test-cluster-1" CLUSTER_C1_1 start_broker "--load-module ${CLUSTER_LIB} --cluster-name test-cluster-1" CLUSTER_C1_2 start_broker "--load-module ${CLUSTER_LIB} --cluster-name test-cluster-2" CLUSTER_C2_1 start_broker "--load-module ${CLUSTER_LIB} --cluster-name test-cluster-2" CLUSTER_C2_2 fi rm qpidd.port } stop_brokers() { ${QPIDD_EXEC} -q --port ${LOCAL_PORT} ${QPIDD_EXEC} -q --port ${REMOTE_PORT} if [ -n "${CLUSTERING_ENABLED}" ]; then ${QPID_CLUSTER_EXEC} --all-stop --force localhost:${CLUSTER_C1_1} ${QPID_CLUSTER_EXEC} --all-stop --force localhost:${CLUSTER_C2_1} fi } if test -d ${PYTHON_DIR} ; then start_brokers if [ -z ${CLUSTERING_ENABLED} ]; then echo "Running federation tests using brokers on local port ${LOCAL_PORT}, remote port ${REMOTE_PORT} (NOTE: clustering is DISABLED)" else echo "Running federation tests using brokers on local port ${LOCAL_PORT}, remote port ${REMOTE_PORT}, local cluster nodes ${CLUSTER_C1_1} ${CLUSTER_C1_2}, remote cluster nodes ${CLUSTER_C2_1} ${CLUSTER_C2_2}" fi if [ -z ${USE_LONG_TEST} ]; then echo "NOTE: To run a full set of federation system tests, use \"make check-long\". To test with persistence, run the store version of this script." fi ${QPID_PYTHON_TEST} -m ${MODULENAME} ${SKIPTESTS} -b localhost:${REMOTE_PORT} -Dlocal-port=${LOCAL_PORT} -Dremote-port=${REMOTE_PORT} -Dlocal-cluster-ports="${CLUSTER_C1_1} ${CLUSTER_C1_2}" -Dremote-cluster-ports="${CLUSTER_C2_1} ${CLUSTER_C2_2}" $@ RETCODE=$? stop_brokers if test x${RETCODE} != x0; then echo "FAIL federation tests"; exit 1; fi fi