mirror of https://github.com/google/oss-fuzz.git
119 lines
4.7 KiB
Bash
Executable File
119 lines
4.7 KiB
Bash
Executable File
#!/bin/bash -eu
|
|
# Copyright 2021 Google LLC
|
|
#
|
|
# 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.
|
|
#
|
|
################################################################################
|
|
|
|
|
|
mkdir $SRC/ClickHouse/build
|
|
cd $SRC/ClickHouse/build
|
|
|
|
sed -i -e '/warnings.cmake)/d' $SRC/ClickHouse/CMakeLists.txt
|
|
|
|
# It will be hard to maintain any compilation fails (if any) in two repositories.
|
|
# Also ClickHouse won't compile without this.
|
|
# It is very strange, because we have as many warnings as you could imagine.
|
|
sed -i -e 's/add_warning(/no_warning(/g' $SRC/ClickHouse/CMakeLists.txt
|
|
|
|
# ClickHouse uses libcxx from contrib.
|
|
# Enabling this manually will cause duplicate symbols at linker stage.
|
|
CXXFLAGS=${CXXFLAGS//-stdlib=libc++/}
|
|
|
|
# ClickHouse builds `protoc` from sources to be dependent only on compiler
|
|
# but if we build ClickHouse with any kind of sanitizer, then `protoc`
|
|
# will be built with sanitizer too...
|
|
# Protoc will be used during ClickHouse builds to generate .cpp sources from .proto files
|
|
# and everything works in our CI, but not here...
|
|
# We use libprotobuf-mutator and self-written script to generate SQL-based AST from mutated .proto
|
|
# Maybe some of proto files are too complex and this is the cause of `protoc` failures
|
|
# So, this flag only helps to supress error from `protoc` built with any kind of sanitizer
|
|
export MSAN_OPTIONS=exit_code=0
|
|
|
|
printenv
|
|
|
|
CLICKHOUSE_CMAKE_FLAGS=(
|
|
"-DCMAKE_CXX_COMPILER_LAUNCHER=/usr/bin/ccache"
|
|
"-DCMAKE_C_COMPILER=$CC"
|
|
"-DCMAKE_CXX_COMPILER=$CXX"
|
|
"-DCMAKE_BUILD_TYPE=RelWithDebInfo"
|
|
"-DLIB_FUZZING_ENGINE:STRING=$LIB_FUZZING_ENGINE"
|
|
"-DENABLE_FUZZING=1"
|
|
"-DWITH_COVERAGE=1"
|
|
"-DENABLE_PROTOBUF=1"
|
|
"-DUSE_INTERNAL_PROTOBUF_LIBRARY=1"
|
|
)
|
|
|
|
if [ "$SANITIZER" = "coverage" ]; then
|
|
cmake -G Ninja $SRC/ClickHouse ${CLICKHOUSE_CMAKE_FLAGS[@]} -DWITH_COVERAGE=1
|
|
else
|
|
cmake -G Ninja $SRC/ClickHouse ${CLICKHOUSE_CMAKE_FLAGS[@]} -DWITH_COVERAGE=1 -DSANITIZE=$SANITIZER
|
|
fi
|
|
|
|
NUM_JOBS=$(($(nproc || grep -c ^processor /proc/cpuinfo) * 2))
|
|
|
|
TARGETS=$(find $SRC/ClickHouse/src -name '*_fuzzer.cpp' -execdir basename {} .cpp ';' | tr '\n' ' ')
|
|
|
|
for FUZZER_TARGET in $TARGETS
|
|
do
|
|
# Skip this fuzzer because of linker errors (the size of the binary is too big)
|
|
if [ "$FUZZER_TARGET" = "execute_query_fuzzer" ]; then
|
|
continue
|
|
fi
|
|
ninja -j $NUM_JOBS $FUZZER_TARGET
|
|
# Find this binary in build directory and strip it
|
|
TEMP=$(find $SRC/ClickHouse/build -name $FUZZER_TARGET)
|
|
strip --strip-unneeded $TEMP
|
|
done
|
|
|
|
# copy out fuzzer binaries
|
|
find $SRC/ClickHouse/build -name '*_fuzzer' -exec cp -v '{}' $OUT ';'
|
|
|
|
# copy out fuzzer options and dictionaries
|
|
cp $SRC/ClickHouse/tests/fuzz/*.dict $OUT/
|
|
cp $SRC/ClickHouse/tests/fuzz/*.options $OUT/
|
|
|
|
# prepare corpus dirs
|
|
mkdir $SRC/ClickHouse/tests/fuzz/lexer_fuzzer.in/
|
|
mkdir $SRC/ClickHouse/tests/fuzz/select_parser_fuzzer.in/
|
|
mkdir $SRC/ClickHouse/tests/fuzz/create_parser_fuzzer.in/
|
|
mkdir $SRC/ClickHouse/tests/fuzz/execute_query_fuzzer.in/
|
|
|
|
# prepare corpus
|
|
cp $SRC/ClickHouse/tests/queries/0_stateless/*.sql $SRC/ClickHouse/tests/fuzz/lexer_fuzzer.in/
|
|
cp $SRC/ClickHouse/tests/queries/0_stateless/*.sql $SRC/ClickHouse/tests/fuzz/select_parser_fuzzer.in/
|
|
cp $SRC/ClickHouse/tests/queries/0_stateless/*.sql $SRC/ClickHouse/tests/fuzz/create_parser_fuzzer.in/
|
|
cp $SRC/ClickHouse/tests/queries/0_stateless/*.sql $SRC/ClickHouse/tests/fuzz/execute_query_fuzzer.in/
|
|
cp $SRC/ClickHouse/tests/queries/1_stateful/*.sql $SRC/ClickHouse/tests/fuzz/lexer_fuzzer.in/
|
|
cp $SRC/ClickHouse/tests/queries/1_stateful/*.sql $SRC/ClickHouse/tests/fuzz/select_parser_fuzzer.in/
|
|
cp $SRC/ClickHouse/tests/queries/1_stateful/*.sql $SRC/ClickHouse/tests/fuzz/create_parser_fuzzer.in/
|
|
cp $SRC/ClickHouse/tests/queries/1_stateful/*.sql $SRC/ClickHouse/tests/fuzz/execute_query_fuzzer.in/
|
|
|
|
# copy out corpus
|
|
cd $SRC/ClickHouse/tests/fuzz
|
|
for dir in *_fuzzer.in; do
|
|
fuzzer=$(basename $dir .in)
|
|
zip -rj "$OUT/${fuzzer}_seed_corpus.zip" "${dir}/"
|
|
done
|
|
|
|
# copy sources for code coverage if required
|
|
if [ "$SANITIZER" = "coverage" ]; then
|
|
mkdir -p $OUT/src/ClickHouse/
|
|
cp -rL --parents $SRC/ClickHouse/src $OUT
|
|
cp -rL --parents $SRC/ClickHouse/base $OUT
|
|
cp -rL --parents $SRC/ClickHouse/programs $OUT
|
|
fi
|
|
|
|
# Just check binaries size
|
|
BINARIES_SIZE=$(find $SRC/ClickHouse/build -name '*_fuzzer' -exec du -sh '{}' ';')
|