1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-18 10:04:20 +03:00

tests: utils better handle ouf of disk space

When the test exhausts all the available free space on storage device,
then during the fail we cannot write anything as well - yet
the teardown needs to finish it's work - otherwise we leave
basicaly overfilled filesystem for all remaining tests.
This commit is contained in:
Zdenek Kabelac 2020-09-18 14:29:15 +02:00
parent b77595ac8b
commit 048e04e417

View File

@ -135,18 +135,23 @@ STACKTRACE() {
# Get backtraces from coredumps # Get backtraces from coredumps
if which gdb &>/dev/null; then if which gdb &>/dev/null; then
{
echo bt full
echo l
echo quit
} > gdb_commands.txt
# Check for all cores newer then TESTNAME file # Check for all cores newer then TESTNAME file
# Assume users keep prefix 'core' # Assume users keep prefix 'core'
# TODO: possibly better integrate with coredumpctl & systemd # TODO: possibly better integrate with coredumpctl & systemd
while IFS= read -r i; do while IFS= read -r i; do
bin=$(gdb -batch -c "$i" 2>&1 | grep "generated by" | \ bin=$(gdb -batch -c "$i" 2>&1 | grep "generated by" | \
sed -e "s,.*generated by \`\([^ ']*\).*,\1,") || continue sed -e "s,.*generated by \`\([^ ']*\).*,\1,") || continue
{
echo bt full
echo l
echo quit
} > gdb_commands.txt || rm -f gdb_commands.txt
if test ! -s gdb_commands.txt ; then
echo "Out of disk space, can't check coredump $i generated by $bin."
continue
fi
echo "## Checking coredump: $i generated by $bin." echo "## Checking coredump: $i generated by $bin."
gdb -batch -c "$i" -x gdb_commands.txt "$(which "$bin")" 2>/dev/null | \ gdb -batch -c "$i" -x gdb_commands.txt "$(which "$bin")" 2>/dev/null | \
sed -e "s,^,## GDB: ," || continue sed -e "s,^,## GDB: ," || continue
@ -171,10 +176,9 @@ STACKTRACE() {
echo "<======== Strace debug log ========>" echo "<======== Strace debug log ========>"
sed -e "s,^,## STRACE: ," strace.log sed -e "s,^,## STRACE: ," strace.log
fi fi
dmsetup info -c | grep1_ "$PREFIX" > out if dmsetup info -c | grep -q "$PREFIX" ; then
if test "$(wc -l < out)" -gt 1 ; then
echo "<======== Info ========>" echo "<======== Info ========>"
sed -e "s,^,## DMINFO: ," out dmsetup info -c | grep1_ "$PREFIX"| sed -e "s,^,## DMINFO: ,"
echo "<======== Active table ========>" echo "<======== Active table ========>"
dmsetup table | grep "$PREFIX" | sed -e "s,^,## DMTABLE: ," dmsetup table | grep "$PREFIX" | sed -e "s,^,## DMTABLE: ,"
echo "<======== Inactive table ========>" echo "<======== Inactive table ========>"