Blame tests/run-stack-demangled-test.sh

Packit Service 97d2fb
#! /bin/sh
Packit Service 97d2fb
# Copyright (C) 2014, 2015 Red Hat, Inc.
Packit Service 97d2fb
# This file is part of elfutils.
Packit Service 97d2fb
#
Packit Service 97d2fb
# This file is free software; you can redistribute it and/or modify
Packit Service 97d2fb
# it under the terms of the GNU General Public License as published by
Packit Service 97d2fb
# the Free Software Foundation; either version 3 of the License, or
Packit Service 97d2fb
# (at your option) any later version.
Packit Service 97d2fb
#
Packit Service 97d2fb
# elfutils is distributed in the hope that it will be useful, but
Packit Service 97d2fb
# WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 97d2fb
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 97d2fb
# GNU General Public License for more details.
Packit Service 97d2fb
#
Packit Service 97d2fb
# You should have received a copy of the GNU General Public License
Packit Service 97d2fb
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
Packit Service 97d2fb
Packit Service 97d2fb
if test -n "$ELFUTILS_DISABLE_DEMANGLE"; then
Packit Service 97d2fb
  echo "demangler unsupported"
Packit Service 97d2fb
  exit 77
Packit Service 97d2fb
fi
Packit Service 97d2fb
Packit Service 97d2fb
. $srcdir/test-subr.sh
Packit Service 97d2fb
Packit Service 97d2fb
# See run-stack-d-test.sh and run-stack-i-test.sh
Packit Service 97d2fb
# Same tests, now with demangler support, no -r, and without -d.
Packit Service 97d2fb
# Only change in output is an explit fu(int) instead of _Z2fui.
Packit Service 97d2fb
Packit Service 97d2fb
testfiles testfiledwarfinlines testfiledwarfinlines.core
Packit Service 97d2fb
Packit Service 97d2fb
# Depending on whether we are running make check or make installcheck
Packit Service 97d2fb
# the actual binary name under test might be different. It is used in
Packit Service 97d2fb
# the error message, which we also try to match.
Packit Service 97d2fb
if test "$elfutils_testrun" = "installed"; then
Packit Service 97d2fb
STACKCMD=${bindir}/`program_transform stack`
Packit Service 97d2fb
else
Packit Service 97d2fb
STACKCMD=${abs_top_builddir}/src/stack
Packit Service 97d2fb
fi
Packit Service 97d2fb
Packit Service 97d2fb
# Disable valgrind while dumping because of a bug unmapping libc.so.
Packit Service 97d2fb
# https://bugs.kde.org/show_bug.cgi?id=327427
Packit Service 97d2fb
SAVED_VALGRIND_CMD="$VALGRIND_CMD"
Packit Service 97d2fb
unset VALGRIND_CMD
Packit Service 97d2fb
Packit Service 97d2fb
# Without -d the top function comes out as fu.
Packit Service 97d2fb
testrun_compare ${abs_top_builddir}/src/stack -n 2 -e testfiledwarfinlines --core testfiledwarfinlines.core<
Packit Service 97d2fb
PID 13654 - core
Packit Service 97d2fb
TID 13654:
Packit Service 97d2fb
#0  0x00000000004006c8 fu(int)
Packit Service 97d2fb
#1  0x00000000004004c5 main
Packit Service 97d2fb
$STACKCMD: tid 13654: shown max number of frames (2, use -n 0 for unlimited)
Packit Service 97d2fb
EOF
Packit Service 97d2fb
Packit Service 97d2fb
# But when asking for source we see it is actually on line 6.
Packit Service 97d2fb
# (Which is in function fubar, not fu).
Packit Service 97d2fb
testrun_compare ${abs_top_builddir}/src/stack -n 2 -s -e testfiledwarfinlines --core testfiledwarfinlines.core<
Packit Service 97d2fb
PID 13654 - core
Packit Service 97d2fb
TID 13654:
Packit Service 97d2fb
#0  0x00000000004006c8 fu(int)
Packit Service 97d2fb
    /home/mark/src/tests/dwarfinlines.cpp:6
Packit Service 97d2fb
#1  0x00000000004004c5 main
Packit Service 97d2fb
    /home/mark/src/tests/dwarfinlines.cpp:39
Packit Service 97d2fb
$STACKCMD: tid 13654: shown max number of frames (2, use -n 0 for unlimited)
Packit Service 97d2fb
EOF
Packit Service 97d2fb
Packit Service 97d2fb
# With --inlines we get all inlined calls. Note they share the same
Packit Service 97d2fb
# address.
Packit Service 97d2fb
testrun_compare ${abs_top_builddir}/src/stack -n 6 -i -e testfiledwarfinlines --core testfiledwarfinlines.core<
Packit Service 97d2fb
PID 13654 - core
Packit Service 97d2fb
TID 13654:
Packit Service 97d2fb
#0  0x00000000004006c8 fubar
Packit Service 97d2fb
#1  0x00000000004006c8 foobar
Packit Service 97d2fb
#2  0x00000000004006c8 bar
Packit Service 97d2fb
#3  0x00000000004006c8 foo
Packit Service 97d2fb
#4  0x00000000004006c8 fu(int)
Packit Service 97d2fb
#5  0x00000000004004c5 main
Packit Service 97d2fb
$STACKCMD: tid 13654: shown max number of frames (6, use -n 0 for unlimited)
Packit Service 97d2fb
EOF
Packit Service 97d2fb
Packit Service 97d2fb
# With --source we can also see where in the source the inlined frames
Packit Service 97d2fb
# where originally called from.
Packit Service 97d2fb
testrun_compare ${abs_top_builddir}/src/stack -n 6 -s -i -e testfiledwarfinlines --core testfiledwarfinlines.core<
Packit Service 97d2fb
PID 13654 - core
Packit Service 97d2fb
TID 13654:
Packit Service 97d2fb
#0  0x00000000004006c8 fubar
Packit Service 97d2fb
    /home/mark/src/tests/dwarfinlines.cpp:6
Packit Service 97d2fb
#1  0x00000000004006c8 foobar
Packit Service 97d2fb
    /home/mark/src/tests/dwarfinlines.cpp:14
Packit Service 97d2fb
#2  0x00000000004006c8 bar
Packit Service 97d2fb
    /home/mark/src/tests/dwarfinlines.cpp:21
Packit Service 97d2fb
#3  0x00000000004006c8 foo
Packit Service 97d2fb
    /home/mark/src/tests/dwarfinlines.cpp:27
Packit Service 97d2fb
#4  0x00000000004006c8 fu(int)
Packit Service 97d2fb
    /home/mark/src/tests/dwarfinlines.cpp:33
Packit Service 97d2fb
#5  0x00000000004004c5 main
Packit Service 97d2fb
    /home/mark/src/tests/dwarfinlines.cpp:39
Packit Service 97d2fb
$STACKCMD: tid 13654: shown max number of frames (6, use -n 0 for unlimited)
Packit Service 97d2fb
EOF
Packit Service 97d2fb
Packit Service 97d2fb
if [ "x$SAVED_VALGRIND_CMD" != "x" ]; then
Packit Service 97d2fb
  VALGRIND_CMD="$SAVED_VALGRIND_CMD"
Packit Service 97d2fb
  export VALGRIND_CMD
Packit Service 97d2fb
fi
Packit Service 97d2fb
Packit Service 97d2fb
exit 0