blob: 6624a7dae3f2c4e0151936b6a995a01e3156a2e8 [file] [log] [blame]
#!/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 all Impala tests.
set -euo pipefail
. $IMPALA_HOME/bin/report_build_error.sh
setup_report_build_error
# Start time of run.
START_TIME=$(date +"%Y-%m-%d %H:%M:%S")
cd "${IMPALA_HOME}"
export IMPALA_MAVEN_OPTIONS="-U"
# Allow unlimited pytest failures
export MAX_PYTEST_FAILURES=0
# When UBSAN_FAIL is "death", the logs are monitored for UBSAN errors. Any errors will
# then cause this script to exit.
#
# When UBSAN_FAIL is "error", monitoring is delayed until tests have finished running.
#
# Any other value ignores UBSAN errors.
: ${UBSAN_FAIL:=error}
export UBSAN_FAIL
if test -v CMAKE_BUILD_TYPE && [[ "${CMAKE_BUILD_TYPE}" =~ 'UBSAN' ]] \
&& [ "${UBSAN_FAIL}" = "death" ]
then
export PID_TO_KILL="$(echo $$)"
mkdir -p "${IMPALA_HOME}/logs"
function killer {
while ! grep -rI ": runtime error: " "${IMPALA_HOME}/logs"
do
sleep 1
if ! test -e "/proc/$PID_TO_KILL"
then
return
fi
done
>&2 echo "Killing process $PID_TO_KILL because it invoked undefined behavior"
kill -9 $PID_TO_KILL
}
killer &
export KILLER_PID="$(echo $!)"
disown
trap "kill -i $KILLER_PID" EXIT
fi
RET_CODE=0
if ! bin/bootstrap_development.sh; then
RET_CODE=1
fi
source bin/impala-config.sh > /dev/null 2>&1
# Sanity check: bootstrap_development.sh should not have modified any of
# the Impala files. This is important for the continued functioning of
# bin/single_node_perf_run.py.
NUM_MODIFIED_FILES=$(git status --porcelain --untracked-files=no | wc -l)
if [[ "${NUM_MODIFIED_FILES}" -ne 0 ]]; then
echo "ERROR: Impala source files were modified during bin/bootstrap_development.sh"
echo "Dumping diff:"
git status --porcelain --untracked-files=no
git --no-pager diff
RET_CODE=1
fi
# Skip tests if build/dataload failed
if [[ $RET_CODE -eq 0 ]]; then
if ! bin/run-all-tests.sh; then
RET_CODE=1
fi
fi
# Always shutdown minicluster at the end and run finalize.sh
testdata/bin/kill-all.sh
bin/jenkins/finalize.sh "${START_TIME}"
exit $RET_CODE