mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/kdave/btrfs-progs.git
synced 2024-12-01 08:04:28 +08:00
4884ae2f5e
Add new keyword to dump the log file after any test fails. Can be useful for remote analysis of test failures. Signed-off-by: David Sterba <dsterba@suse.com>
44 lines
841 B
Bash
Executable File
44 lines
841 B
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# misc tests on fuzzed or crafted images
|
|
|
|
LANG=C
|
|
SCRIPT_DIR=$(dirname $(readlink -f "$0"))
|
|
TOP=$(readlink -f "$SCRIPT_DIR/../")
|
|
TEST_DEV=${TEST_DEV:-}
|
|
RESULTS="$TOP/tests/fuzz-tests-results.txt"
|
|
IMAGE="$TOP/tests/test.img"
|
|
|
|
source "$TOP/tests/common"
|
|
|
|
export TOP
|
|
export RESULTS
|
|
export LANG
|
|
export IMAGE
|
|
export TEST_DEV
|
|
|
|
rm -f "$RESULTS"
|
|
|
|
check_prereq btrfs
|
|
|
|
# The tests are driven by their custom script called 'test.sh'
|
|
|
|
for i in $(find "$TOP/tests/fuzz-tests" -maxdepth 1 -mindepth 1 -type d \
|
|
${TEST:+-name "$TEST"} | sort)
|
|
do
|
|
name=$(basename "$i")
|
|
cd $i
|
|
if [ -x test.sh ]; then
|
|
echo "=== Entering $i" >> "$RESULTS"
|
|
echo " [TEST/fuzz] $name"
|
|
./test.sh
|
|
if [ $? -ne 0 ]; then
|
|
if [[ $TEST_LOG =~ dump ]]; then
|
|
cat "$RESULTS"
|
|
fi
|
|
_fail "test failed for case $(basename $i)"
|
|
fi
|
|
fi
|
|
cd "$TOP"
|
|
done
|