From fec9b02faff6dc541f12effafe3563cb08a032dc Mon Sep 17 00:00:00 2001 From: Tobias Brunner Date: Wed, 3 May 2017 16:56:53 +0200 Subject: [PATCH] strongswan: Run first fuzz target in fuzzing branch (#562) --- projects/strongswan/Dockerfile | 23 +++++++++++++++++++++++ projects/strongswan/build.sh | 33 +++++++++++++++++++++++++++++++++ 2 files changed, 56 insertions(+) create mode 100644 projects/strongswan/Dockerfile create mode 100644 projects/strongswan/build.sh diff --git a/projects/strongswan/Dockerfile b/projects/strongswan/Dockerfile new file mode 100644 index 000000000..3fd996b71 --- /dev/null +++ b/projects/strongswan/Dockerfile @@ -0,0 +1,23 @@ +# Copyright 2017 Google Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +############################################################################## + +FROM gcr.io/oss-fuzz-base/base-builder +MAINTAINER tobias@strongswan.org +RUN apt-get update && apt-get install -y automake autoconf libtool pkg-config gettext perl python flex bison gperf lcov libgmp3-dev +RUN git clone -b fuzzing --depth 1 https://github.com/strongswan/strongswan.git strongswan +RUN git clone --depth 1 https://github.com/strongswan/fuzzing-corpora.git strongswan/fuzzing-corpora +WORKDIR strongswan +COPY build.sh $SRC/ diff --git a/projects/strongswan/build.sh b/projects/strongswan/build.sh new file mode 100644 index 000000000..9eada828d --- /dev/null +++ b/projects/strongswan/build.sh @@ -0,0 +1,33 @@ +#!/bin/bash -eu +# Copyright 2017 Google Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +################################################################################ + +./autogen.sh + +./configure CFLAGS="$CFLAGS -DNO_CHECK_MEMWIPE" LDFLAGS='--coverage' --enable-fuzzing --enable-coverage --with-libfuzzer=$LIB_FUZZING_ENGINE --enable-monolithic --disable-shared --enable-static + +make -j$(nproc) + +fuzzers=$(find fuzz -maxdepth 1 -executable -type f -name \fuzz_*) +for f in $fuzzers; do + fuzzer=$(basename $f) + cp $f $OUT/ + corpus=${fuzzer#fuzz_} + corpus=${corpus%%_*} + if [ -d "fuzzing-corpora/${corpus}" ]; then + zip -rj $OUT/${fuzzer}_seed_corpus.zip fuzzing-corpora/${corpus} + fi +done