51 lines
1.2 KiB
Bash
Executable File
51 lines
1.2 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
REPO_DIR=$(git rev-parse --show-toplevel)
|
|
|
|
listTargetFiles() {
|
|
pushd "$REPO_DIR/fuzz" > /dev/null || exit 1
|
|
find fuzz_targets/ -type f -name "*.rs"
|
|
popd > /dev/null || exit 1
|
|
}
|
|
|
|
targetFileToName() {
|
|
echo "$1" \
|
|
| sed 's/^fuzz_targets\///' \
|
|
| sed 's/\.rs$//' \
|
|
| sed 's/\//_/g'
|
|
}
|
|
|
|
targetFileToHFuzzInputArg() {
|
|
baseName=$(basename "$1")
|
|
dirName="${baseName%.*}"
|
|
if [ -d "hfuzz_input/$dirName" ]; then
|
|
echo "HFUZZ_INPUT_ARGS=\"-f hfuzz_input/$FILE/input\""
|
|
fi
|
|
}
|
|
|
|
listTargetNames() {
|
|
for target in $(listTargetFiles); do
|
|
targetFileToName "$target"
|
|
done
|
|
}
|
|
|
|
# Utility function to avoid CI failures on Windows
|
|
checkWindowsFiles() {
|
|
incorrectFilenames=$(find . -type f -name "*,*" -o -name "*:*" -o -name "*<*" -o -name "*>*" -o -name "*|*" -o -name "*\?*" -o -name "*\**" -o -name "*\"*" | wc -l)
|
|
if [ "$incorrectFilenames" -gt 0 ]; then
|
|
exit 2
|
|
fi
|
|
}
|
|
|
|
# Checks whether a fuzz case output some report, and dumps it in hex
|
|
checkReport() {
|
|
reportFile="hfuzz_workspace/$1/HONGGFUZZ.REPORT.TXT"
|
|
if [ -f "$reportFile" ]; then
|
|
cat "$reportFile"
|
|
for CASE in "hfuzz_workspace/$1/SIG"*; do
|
|
xxd -p -c10000 < "$CASE"
|
|
done
|
|
exit 1
|
|
fi
|
|
}
|