mirror of
https://github.com/kdave/btrfs-progs
synced 2025-01-24 06:22:46 +00:00
2726a83952
Some errors may be reported in the logs only, scan the file each time there are fresh results. The scanning script will return error that is supposed to be caught by the testsuite environment. Signed-off-by: David Sterba <dsterba@suse.com>
40 lines
978 B
Bash
Executable File
40 lines
978 B
Bash
Executable File
#!/bin/sh
|
|
# Look for some frequent error message templates in test logs
|
|
#
|
|
# Usage: $0 [test-log.txt]
|
|
|
|
ret=0
|
|
|
|
scan_log() {
|
|
local file="$1"
|
|
|
|
echo "Scanning $file"
|
|
last=
|
|
while read line; do
|
|
case "$line" in
|
|
===\ START\ TEST*) last="$line" ;;
|
|
*Assertion*failed*) ret=1; echo "ASSERTION FAILED: $last" ;;
|
|
*runtime\ error*) ret=1; echo "RUNTIME ERROR (sanitizer): $last" ;;
|
|
*AddressSanitizer*heap-use-after-free*) ret=1; echo "RUNTIME ERROR (use after free): $last" ;;
|
|
*LeakSanitizer:*leak*) ret=1; echo "SANITIZER REPORT: memory leak: $last" ;;
|
|
*Warning:\ assertion*failed*) ret=1; echo "ASSERTION WARNING: $last" ;;
|
|
*command\ not\ found*) ret=1; echo "COMMAND NOT FOUND: $last" ;;
|
|
*extent\ buffer\ leak*) ret=1; echo "EXTENT BUFFER LEAK: $last" ;;
|
|
*) : ;;
|
|
esac
|
|
done < "$file"
|
|
}
|
|
|
|
# Scan only the given file
|
|
if [ -n "$1" ]; then
|
|
scan_log "$1"
|
|
exit "$ret"
|
|
fi
|
|
|
|
# Scan all existing test logs
|
|
for file in *.txt; do
|
|
scan_log "$file"
|
|
done
|
|
|
|
exit "$ret"
|