mirror of
https://github.com/mirror/wget.git
synced 2025-01-18 08:10:42 +08:00
a4402120ad
* Makefile.am: Add fuzz/ to SUBDIRS * cfg.mk: Fix 'make syntax-check' * configure.ac: Add --enable-fuzzing * fuzz/Makefile.am: New file * fuzz/README.md: New file * fuzz/fuzzer.h: New file * fuzz/get_all_corpora: New file * fuzz/get_ossfuzz_corpora: New file * fuzz/glob_crash.c: New file * fuzz/main.c: New file * fuzz/run-afl.sh: New file * fuzz/run-clang.sh: New file * fuzz/view-coverage.sh: New file * fuzz/wget_options_fuzzer.c: New file * fuzz/wget_options_fuzzer.dict: New file * src/init.c (cleanup): Free more resources * src/main.c (init_switches): Initialize only once, (print_usage): Don't print if TESTING is defined * src/utils.h: Include wget.h
58 lines
1.6 KiB
Bash
Executable File
58 lines
1.6 KiB
Bash
Executable File
#!/bin/bash -e
|
|
#
|
|
# Copyright(c) 2017 Free Software Foundation, Inc.
|
|
#
|
|
# This file is part of GNU Wget.
|
|
#
|
|
# GNU Wget is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Lesser General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# GNU Wget is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public License
|
|
# along with GNU Wget. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
trap ctrl_c INT
|
|
|
|
ctrl_c() {
|
|
./${fuzzer} -merge=1 ${fuzzer}.in ${fuzzer}.new
|
|
rm -rf ${fuzzer}.new
|
|
}
|
|
|
|
if test -z "$1"; then
|
|
echo "Usage: $0 <fuzzer target>"
|
|
echo "Example: $0 wget_options_fuzzer"
|
|
exit 1
|
|
fi
|
|
|
|
if ! grep -q FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION Makefile; then
|
|
echo "The fuzzers haven't been built for fuzzing (maybe for regression testing !?)"
|
|
echo "Please built regarding README.md and try again."
|
|
exit 1
|
|
fi
|
|
|
|
# you'll need ~2GB free memory per worker !
|
|
fuzzer=$1
|
|
workers=$(($(nproc) - 0))
|
|
jobs=$workers
|
|
|
|
if test -n "$BUILD_ONLY"; then
|
|
exit 0
|
|
fi
|
|
|
|
# create directory for NEW test corpora (covering new areas of code)
|
|
mkdir -p ${fuzzer}.new
|
|
|
|
if test -f ${fuzzer}.dict; then
|
|
./${fuzzer} -detect_leaks=0 -dict=${fuzzer}.dict ${fuzzer}.new ${fuzzer}.in -jobs=$jobs -workers=$workers
|
|
else
|
|
./${fuzzer} ${fuzzer}.new ${fuzzer}.in -jobs=$jobs -workers=$workers -detect_leaks=0
|
|
fi
|
|
|
|
exit 0
|