mirror of https://github.com/google/oss-fuzz.git
[spdlog] Added new fuzzers, modifed existing ones
This commit is contained in:
parent
b2a532bae2
commit
1e7f14a81d
|
@ -20,5 +20,8 @@ MAINTAINER gmelman1@gmail.com
|
|||
RUN apt-get update && apt-get install --yes cmake
|
||||
|
||||
RUN git clone --depth 1 https://github.com/gabime/spdlog.git
|
||||
RUN zip spdlog_fuzzer_seed_corpus.zip spdlog/example/*
|
||||
WORKDIR spdlog
|
||||
COPY build.sh log_fuzzer.cc $SRC/
|
||||
COPY build.sh spdlog_fuzzer.dict $SRC/
|
||||
COPY *\.cc $SRC/
|
||||
COPY *\.options $SRC/
|
|
@ -0,0 +1,43 @@
|
|||
// Copyright 2019 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.
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
#include <fuzzer/FuzzedDataProvider.h>
|
||||
|
||||
#include "spdlog/spdlog.h"
|
||||
#include "spdlog/sinks/basic_file_sink.h"
|
||||
|
||||
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||
static std::shared_ptr<spdlog::logger> my_logger;
|
||||
if (!my_logger.get()) {
|
||||
my_logger = spdlog::basic_logger_mt("basic_logger", "/dev/null");
|
||||
spdlog::set_default_logger(my_logger);
|
||||
}
|
||||
|
||||
if (size == 0) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
FuzzedDataProvider stream(data, size);
|
||||
|
||||
const uint16_t size_arg = stream.ConsumeIntegral<uint16_t>();
|
||||
|
||||
spdlog::enable_backtrace(size_arg);
|
||||
for(int i=0; i<size_arg; i++){
|
||||
spdlog::debug(stream.ConsumeRandomLengthString(size));
|
||||
}
|
||||
spdlog::dump_backtrace();
|
||||
return 0;
|
||||
}
|
|
@ -25,3 +25,6 @@ for f in $(find $SRC -name '*_fuzzer.cc'); do
|
|||
$f $LIB_FUZZING_ENGINE ./libspdlog.a \
|
||||
-o $OUT/$b
|
||||
done
|
||||
|
||||
cp $SRC/spdlog_fuzzer_seed_corpus.zip $OUT/
|
||||
cp $SRC/*.dict $SRC/*.options $OUT/
|
||||
|
|
|
@ -0,0 +1,70 @@
|
|||
// Copyright 2019 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.
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
#include <fuzzer/FuzzedDataProvider.h>
|
||||
|
||||
#include "spdlog/spdlog.h"
|
||||
#include "spdlog/sinks/basic_file_sink.h"
|
||||
#include "spdlog/pattern_formatter.h"
|
||||
|
||||
|
||||
std::string my_formatter_txt = "custom-flag";
|
||||
|
||||
class my_formatter_flag : public spdlog::custom_flag_formatter
|
||||
{
|
||||
|
||||
public:
|
||||
void format(const spdlog::details::log_msg &, const std::tm &, spdlog::memory_buf_t &dest) override
|
||||
{
|
||||
dest.append(my_formatter_txt.data(), my_formatter_txt.data() + my_formatter_txt.size());
|
||||
}
|
||||
|
||||
std::unique_ptr<custom_flag_formatter> clone() const override
|
||||
{
|
||||
return spdlog::details::make_unique<my_formatter_flag>();
|
||||
}
|
||||
};
|
||||
|
||||
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||
static std::shared_ptr<spdlog::logger> my_logger;
|
||||
if (!my_logger.get()) {
|
||||
my_logger = spdlog::basic_logger_mt("basic_logger", "/dev/null");
|
||||
spdlog::set_default_logger(my_logger);
|
||||
}
|
||||
|
||||
if (size == 0) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
FuzzedDataProvider stream(data, size);
|
||||
|
||||
const unsigned long size_arg = stream.ConsumeIntegral<unsigned long>();
|
||||
const unsigned long int_arg = stream.ConsumeIntegral<unsigned long>();
|
||||
const char flag = (char)(stream.ConsumeIntegral<unsigned char>());
|
||||
const std::string pattern = stream.ConsumeRandomLengthString();
|
||||
my_formatter_txt = stream.ConsumeRandomLengthString();
|
||||
const std::string string_arg = stream.ConsumeRandomLengthString();
|
||||
const std::string format_string = stream.ConsumeRemainingBytesAsString();
|
||||
|
||||
using spdlog::details::make_unique;
|
||||
auto formatter = make_unique<spdlog::pattern_formatter>();
|
||||
formatter->add_flag<my_formatter_flag>(flag).set_pattern(pattern);
|
||||
spdlog::set_formatter(std::move(formatter));
|
||||
|
||||
spdlog::info(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,2 @@
|
|||
[libfuzzer]
|
||||
dict = spdlog_fuzzer.dict
|
|
@ -0,0 +1,56 @@
|
|||
// Copyright 2019 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.
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
#include <fuzzer/FuzzedDataProvider.h>
|
||||
|
||||
#include "spdlog/spdlog.h"
|
||||
#include "spdlog/sinks/basic_file_sink.h"
|
||||
#include "spdlog/cfg/argv.h"
|
||||
#include "spdlog/cfg/env.h"
|
||||
|
||||
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||
static std::shared_ptr<spdlog::logger> my_logger;
|
||||
if (!my_logger.get()) {
|
||||
my_logger = spdlog::basic_logger_mt("basic_logger", "/dev/null");
|
||||
spdlog::set_default_logger(my_logger);
|
||||
}
|
||||
|
||||
if (size == 0) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
FuzzedDataProvider stream(data, size);
|
||||
|
||||
|
||||
std::vector<std::string> strings;
|
||||
const unsigned char strsize = stream.ConsumeIntegral<unsigned char>();
|
||||
for(unsigned char i=0; i<strsize; i++){
|
||||
strings.push_back(stream.ConsumeRandomLengthString());
|
||||
}
|
||||
std::vector<char*> argvv; argvv.reserve(strsize);
|
||||
for(unsigned char i=0; i< strsize; ++i)
|
||||
argvv.push_back(const_cast<char*>(strings[i].c_str()));
|
||||
|
||||
const unsigned char int_arg = strsize;
|
||||
if(int_arg==0) return 0;
|
||||
|
||||
const char** argv = (const char**) &argvv[0];
|
||||
spdlog::cfg::load_env_levels();
|
||||
spdlog::cfg::load_argv_levels(int_arg, argv);
|
||||
spdlog::info(stream.ConsumeRemainingBytesAsString());
|
||||
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,2 @@
|
|||
[libfuzzer]
|
||||
dict = spdlog_fuzzer.dict
|
|
@ -30,13 +30,27 @@ extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
|||
return 0;
|
||||
}
|
||||
|
||||
|
||||
FuzzedDataProvider stream(data, size);
|
||||
|
||||
const size_t size_arg = stream.ConsumeIntegral<size_t>();
|
||||
const int int_arg = stream.ConsumeIntegral<int>();
|
||||
const unsigned long size_arg = stream.ConsumeIntegral<unsigned long>();
|
||||
const unsigned long int_arg = stream.ConsumeIntegral<unsigned long>();
|
||||
const std::string string_arg = stream.ConsumeRandomLengthString(size);
|
||||
const std::string format_string = stream.ConsumeRemainingBytesAsString();
|
||||
|
||||
spdlog::info(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
spdlog::trace(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
spdlog::debug(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
spdlog::error(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
spdlog::warn(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
spdlog::critical(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
|
||||
SPDLOG_INFO(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
SPDLOG_TRACE(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
SPDLOG_DEBUG(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
SPDLOG_ERROR(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
SPDLOG_WARN(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
SPDLOG_CRITICAL(format_string.c_str(), size_arg, int_arg, string_arg);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -0,0 +1,2 @@
|
|||
[libfuzzer]
|
||||
dict = spdlog_fuzzer.dict
|
|
@ -0,0 +1,38 @@
|
|||
// Copyright 2019 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.
|
||||
|
||||
#include <cstddef>
|
||||
|
||||
#include <fuzzer/FuzzedDataProvider.h>
|
||||
|
||||
#include "spdlog/spdlog.h"
|
||||
#include "spdlog/sinks/basic_file_sink.h"
|
||||
|
||||
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||
static std::shared_ptr<spdlog::logger> my_logger;
|
||||
if (!my_logger.get()) {
|
||||
my_logger = spdlog::basic_logger_mt("basic_logger", "/dev/null");
|
||||
spdlog::set_default_logger(my_logger);
|
||||
}
|
||||
|
||||
if (size == 0) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
FuzzedDataProvider stream(data, size);
|
||||
const std::string str = stream.ConsumeRemainingBytesAsString();
|
||||
spdlog::set_pattern(str);
|
||||
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,2 @@
|
|||
[libfuzzer]
|
||||
dict = spdlog_fuzzer.dict
|
|
@ -6,4 +6,4 @@ auto_ccs:
|
|||
sanitizers:
|
||||
- address
|
||||
- memory
|
||||
- undefined
|
||||
- undefined
|
|
@ -0,0 +1,20 @@
|
|||
"{}"
|
||||
"{:08d}"
|
||||
"{0:d}"
|
||||
"{0:x}"
|
||||
"{0:o}"
|
||||
"{0:b}"
|
||||
"{:03.2f}"
|
||||
"{1}"
|
||||
"{0}"
|
||||
"{:<8}"
|
||||
"{:<999999999999999999999999}"
|
||||
"[%H:%M:%S %z]"
|
||||
"[%^%L%$]"
|
||||
"[thread %t]"
|
||||
"%v"
|
||||
"%+"
|
||||
"{:X}"
|
||||
"{:s}"
|
||||
"{:p}"
|
||||
"{:n}"
|
Loading…
Reference in New Issue