# Copyright 2016 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 ossfuzz/base-libfuzzer MAINTAINER alex.gaynor@gmail.com RUN apt-get install -y make autoconf automake libtool autopoint libnettle6 nettle-dev pkg-config gperf bison autogen texinfo curl RUN git clone --depth=1 https://gitlab.com/gnutls/gnutls.git RUN cd gnutls && git submodule update --init # clone OpenSSL to get it's fuzzer testcases RUN git clone --depth=1 https://github.com/openssl/openssl # Using the client_corpus transcripts from BoringSSL and OpenSSL, they're a # decent starting point. RUN mkdir client-testcases RUN cd client-testcases/ && curl https://boringssl.googlesource.com/boringssl/+archive/master/fuzz/client_corpus.tar.gz | tar -zx RUN cd client-testcases/ && curl https://boringssl.googlesource.com/boringssl/+archive/master/fuzz/client_corpus_no_fuzzer_mode.tar.gz | tar -zx RUN cp openssl/fuzz/corpora/client/* client-testcases/ RUN zip gnutls_client_fuzzer_seed_corpus.zip client-testcases/* # Same thing for X.509 RUN mkdir x509-testcases RUN cd x509-testcases/ && curl https://boringssl.googlesource.com/boringssl/+archive/master/fuzz/cert_corpus.tar.gz | tar -zx RUN cp openssl/fuzz/corpora/x509/* x509-testcases/ RUN zip gnutls_x509_parser_fuzzer_seed_corpus.zip x509-testcases/* WORKDIR gnutls COPY build.sh gnutls_client_fuzzer.cc gnutls_x509_parser_fuzzer.cc $SRC/