mirror of
https://github.com/systemd/systemd.git
synced 2024-11-02 10:51:20 +03:00
c667e09ba0
Since clang was updated to 9.0.1 libFuzzer has been exiting with 72 when it's run with timeout. Let's pass -max_total_time to it instead.
42 lines
1.4 KiB
Bash
Executable File
42 lines
1.4 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -e
|
|
set -x
|
|
set -u
|
|
|
|
REPO_ROOT=${REPO_ROOT:-$(pwd)}
|
|
|
|
sudo bash -c "echo 'deb-src http://archive.ubuntu.com/ubuntu/ xenial main restricted universe multiverse' >>/etc/apt/sources.list"
|
|
sudo apt-get update -y
|
|
sudo apt-get build-dep systemd -y
|
|
sudo apt-get install -y ninja-build python3-pip python3-setuptools quota
|
|
# The following should be dropped when debian packaging has been updated to include them
|
|
sudo apt-get install -y libfdisk-dev libp11-kit-dev libssl-dev libpwquality-dev
|
|
pip3 install meson
|
|
|
|
cd $REPO_ROOT
|
|
export PATH="$HOME/.local/bin/:$PATH"
|
|
tools/oss-fuzz.sh
|
|
./out/fuzz-unit-file -max_total_time=5
|
|
git clean -dxff
|
|
|
|
wget https://app.fuzzbuzz.io/releases/cli/latest/linux/fuzzbuzz
|
|
chmod +x fuzzbuzz
|
|
./fuzzbuzz validate
|
|
./fuzzbuzz target test fuzz-unit-file --all
|
|
|
|
git clone https://github.com/google/oss-fuzz /tmp/oss-fuzz
|
|
cd /tmp/oss-fuzz
|
|
sudo ./infra/helper.py pull_images
|
|
|
|
# docker doesn't like colons in filenames so let's create a directory
|
|
# whose name can be consumed by the -v option.
|
|
# https://github.com/google/oss-fuzz/issues/2428
|
|
t=$(mktemp -d)
|
|
sudo mount --bind "$REPO_ROOT" "$t"
|
|
|
|
# helper.py is wrapped in script to trick it into thinking it's "interactive"
|
|
# See https://github.com/systemd/systemd/pull/12542#issuecomment-491563572
|
|
sudo script -e -c "./infra/helper.py build_fuzzers --clean --sanitizer=memory systemd $t"
|
|
sudo script -e -c "./infra/helper.py check_build --sanitizer=memory -e ALLOWED_BROKEN_TARGETS_PERCENTAGE=0 systemd"
|