2017-07-14 10:42:01 -07:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
2018-03-02 09:10:52 -08:00
|
|
|
set -eux
|
2017-07-14 10:42:01 -07:00
|
|
|
|
2018-03-02 09:10:52 -08:00
|
|
|
root=$(dirname "$0")/..
|
|
|
|
|
export ASAN_OPTIONS="quarantine_size_mb=10:detect_leaks=1:symbolize=1"
|
|
|
|
|
export UBSAN="print_stacktrace=1:halt_on_error=1:symbolize=1"
|
|
|
|
|
|
2023-07-19 22:20:01 -04:00
|
|
|
# check if CI env var exists
|
|
|
|
|
|
|
|
|
|
if [ -z "${CI:-}" ]; then
|
|
|
|
|
declare -A mode_config=( ["halt"]="-timeout=1 -rss_limit_mb=2048" ["recover"]="-timeout=10 -rss_limit_mb=2048" )
|
|
|
|
|
else
|
|
|
|
|
declare -A mode_config=( ["halt"]="-max_total_time=120 -timeout=1 -rss_limit_mb=2048" ["recover"]="-time=120 -timeout=10 -rss_limit_mb=2048" )
|
|
|
|
|
fi
|
2018-03-02 09:10:52 -08:00
|
|
|
|
2024-02-11 12:17:09 +01:00
|
|
|
if [ "$#" -lt 2 ]; then
|
|
|
|
|
echo "usage: $0 <language> <halt|recover> <libFuzzer args...>"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2017-07-14 10:42:01 -07:00
|
|
|
|
2024-02-11 12:17:09 +01:00
|
|
|
lang="$1"
|
|
|
|
|
shift
|
|
|
|
|
mode="$1"
|
|
|
|
|
shift
|
|
|
|
|
# Treat remainder of arguments as libFuzzer arguments
|
2018-03-02 09:10:52 -08:00
|
|
|
|
2024-02-11 12:17:09 +01:00
|
|
|
# Fuzzing logs and testcases are always written to `pwd`, so `cd` there first
|
|
|
|
|
results="${root}/test/fuzz/out/fuzz-results/${lang}"
|
|
|
|
|
mkdir -p "${results}"
|
|
|
|
|
cd "${results}"
|
2018-03-02 09:10:52 -08:00
|
|
|
|
2024-02-11 12:17:09 +01:00
|
|
|
# Create a corpus directory, so new discoveries are stored on disk. These will
|
|
|
|
|
# then be loaded on subsequent fuzzing runs
|
|
|
|
|
mkdir -p corpus
|
2018-03-02 09:10:52 -08:00
|
|
|
|
2024-02-11 12:17:09 +01:00
|
|
|
pwd
|
|
|
|
|
"../../${lang}_fuzzer" "-dict=../../${lang}.dict" "-artifact_prefix=${lang}_" -max_len=2048 "${mode_config[$mode]}" "./corpus" "$@"
|