Home | History | Annotate | Line # | Download | only in tests
      1 #!/bin/sh
      2 #
      3 # Copyright (C) Internet Systems Consortium, Inc. ("ISC")
      4 #
      5 # SPDX-License-Identifier: MPL-2.0
      6 #
      7 # This Source Code Form is subject to the terms of the Mozilla Public
      8 # License, v. 2.0. If a copy of the MPL was not distributed with this
      9 # file, you can obtain one at https://mozilla.org/MPL/2.0/.
     10 #
     11 # See the COPYRIGHT file distributed with this work for additional
     12 # information regarding copyright ownership.
     13 
     14 TOP_BUILDDIR=@abs_top_builddir@
     15 TOP_SRCDIR=@abs_top_srcdir@
     16 
     17 if [ -z "${1}" ]; then
     18   echo "Usage: ${0} test_program" >&2
     19   exit 1
     20 fi
     21 
     22 TEST_PROGRAM="${1}"
     23 TIMEOUT=300
     24 
     25 "${TEST_PROGRAM}" &
     26 TEST_PROGRAM_PID=${!}
     27 STATUS=124
     28 while [ ${TIMEOUT} -gt 0 ]; do
     29   if ! kill -0 "${TEST_PROGRAM_PID}" 2>/dev/null; then
     30     wait "${TEST_PROGRAM_PID}"
     31     STATUS=${?}
     32     break
     33   fi
     34   sleep 1
     35   TIMEOUT=$((TIMEOUT - 1))
     36 done
     37 if [ ${TIMEOUT} -eq 0 ]; then
     38   echo "PID ${TEST_PROGRAM_PID} exceeded run time limit, sending SIGABRT" >&2
     39   kill -ABRT "${TEST_PROGRAM_PID}" 2>/dev/null
     40 fi
     41 
     42 TEST_PROGRAM_NAME=$(basename "${TEST_PROGRAM}")
     43 TEST_PROGRAM_WORK_DIR=$(dirname "${TEST_PROGRAM}")
     44 find "${TEST_PROGRAM_WORK_DIR}" -name 'core*' -or -name '*.core' | while read -r CORE_DUMP; do
     45   BINARY=$(gdb --batch --core="${CORE_DUMP}" 2>/dev/null | sed -n "s/^Core was generated by \`\(.*\)'\.\$/\1/p")
     46   if ! echo "${BINARY}" | grep -q "${TEST_PROGRAM_NAME}\$"; then
     47     continue
     48   fi
     49   echo "I:${TEST_PROGRAM_NAME}:Core dump found: ${CORE_DUMP}"
     50   echo "D:${TEST_PROGRAM_NAME}:backtrace from ${CORE_DUMP} start"
     51   "${TOP_BUILDDIR}/libtool" --mode=execute gdb \
     52     --batch \
     53     --command="${TOP_SRCDIR}/bin/tests/system/run.gdb" \
     54     --core="${CORE_DUMP}" \
     55     -- \
     56     "${BINARY}"
     57   echo "D:${TEST_PROGRAM_NAME}:backtrace from ${CORE_DUMP} end"
     58 done
     59 
     60 exit ${STATUS}
     61