Files
impala/bin/run-backend-tests.sh
Gergely Fürnstáhl b5524e95a1 IMPALA-11935: Generate core dumps if ASAN/TSAN/UBSAN built be tests crash
By default, on 64-bit systems, programs built with sanitizers do not
produce minidumps nor coredumps due to the shadow memory - which is used
for house keeping - being huge and the generated dumps would be too
big (~16TB).

https://gcc.gnu.org/bugzilla//show_bug.cgi?id=89868

The shadow memory can be stripped on exit and the core
dumps can be generated by setting the (T|A|UB)SAN_OPTIONS environment
variable before running the program.

https://stackoverflow.com/questions/42851670/how-to-generate-core-dump-on-addresssanitizer-error

This can help investigating crashes in sanitized builds.

Testing:
 - Locally injected an std::abort() to a test case, built it with TSAN
and verified the creation of the core dump and gdb showed the correct
stack frame.

Change-Id: Idd868fe0f666d683084a24808dd0dcd7766b837c
Reviewed-on: http://gerrit.cloudera.org:8080/19598
Reviewed-by: Impala Public Jenkins <impala-public-jenkins@cloudera.com>
Tested-by: Impala Public Jenkins <impala-public-jenkins@cloudera.com>
2023-03-10 14:23:01 +00:00

47 lines
1.6 KiB
Bash
Executable File

#!/usr/bin/env 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.
set -euo pipefail
. $IMPALA_HOME/bin/report_build_error.sh
setup_report_build_error
export GTEST_OUTPUT="xml:$IMPALA_BE_TEST_LOGS_DIR/"
: ${SKIP_BE_TEST_PATTERN:=}
# The backend unit tests currently do not work when HEAPCHECK is enabled.
export HEAPCHECK=
BE_TEST_ARGS=""
if [[ -n "$SKIP_BE_TEST_PATTERN" ]]; then
BE_TEST_ARGS="-E ${SKIP_BE_TEST_PATTERN}"
fi
cd ${IMPALA_BE_DIR}
. ${IMPALA_HOME}/bin/set-classpath.sh
cd ..
export CTEST_OUTPUT_ON_FAILURE=1
export TSAN_OPTIONS="disable_coredump=0:unmap_shadow_on_exit=1"
export ASAN_OPTIONS="disable_coredump=0:unmap_shadow_on_exit=1"
export UBSAN_OPTIONS="disable_coredump=0:unmap_shadow_on_exit=1"
export PATH="${IMPALA_TOOLCHAIN_PACKAGES_HOME}/llvm-${IMPALA_LLVM_VERSION}/bin:${PATH}"
"${MAKE_CMD:-make}" test ARGS="${BE_TEST_ARGS}"