Made use of libfuzzer

This commit is contained in:
eidheim 2020-08-08 10:52:11 +02:00
commit f6df4cde4e
9 changed files with 107 additions and 13 deletions

View file

@ -4,21 +4,57 @@ if(NOT MSVC)
add_compile_options(-Wno-thread-safety)
endif()
add_executable(io_test io_test.cpp)
target_link_libraries(io_test simple-web-server)
add_test(NAME io_test COMMAND io_test)
add_executable(parse_test parse_test.cpp)
target_link_libraries(parse_test simple-web-server)
add_test(NAME parse_test COMMAND parse_test)
if(BUILD_TESTING)
add_executable(io_test io_test.cpp)
target_link_libraries(io_test simple-web-server)
add_test(NAME io_test COMMAND io_test)
add_executable(parse_test parse_test.cpp)
target_link_libraries(parse_test simple-web-server)
add_test(NAME parse_test COMMAND parse_test)
endif()
endif()
if(OPENSSL_FOUND)
if(OPENSSL_FOUND AND BUILD_TESTING)
add_executable(crypto_test crypto_test.cpp)
target_link_libraries(crypto_test simple-web-server)
add_test(NAME crypto_test COMMAND crypto_test)
endif()
add_executable(status_code_test status_code_test.cpp)
target_link_libraries(status_code_test simple-web-server)
add_test(NAME status_code_test COMMAND status_code_test)
if(BUILD_TESTING)
add_executable(status_code_test status_code_test.cpp)
target_link_libraries(status_code_test simple-web-server)
add_test(NAME status_code_test COMMAND status_code_test)
endif()
if(BUILD_FUZZING)
add_executable(percent_decode fuzzers/percent_decode.cpp)
target_compile_options(percent_decode PRIVATE -fsanitize=address,fuzzer)
target_link_options(percent_decode PRIVATE -fsanitize=address,fuzzer)
target_link_libraries(percent_decode simple-web-server)
add_executable(query_string_parse fuzzers/query_string_parse.cpp)
target_compile_options(query_string_parse PRIVATE -fsanitize=address,fuzzer)
target_link_options(query_string_parse PRIVATE -fsanitize=address,fuzzer)
target_link_libraries(query_string_parse simple-web-server)
add_executable(http_header_parse fuzzers/http_header_parse.cpp)
target_compile_options(http_header_parse PRIVATE -fsanitize=address,fuzzer)
target_link_options(http_header_parse PRIVATE -fsanitize=address,fuzzer)
target_link_libraries(http_header_parse simple-web-server)
add_executable(http_header_field_value_semicolon_separated_attributes_parse fuzzers/http_header_field_value_semicolon_separated_attributes_parse.cpp)
target_compile_options(http_header_field_value_semicolon_separated_attributes_parse PRIVATE -fsanitize=address,fuzzer)
target_link_options(http_header_field_value_semicolon_separated_attributes_parse PRIVATE -fsanitize=address,fuzzer)
target_link_libraries(http_header_field_value_semicolon_separated_attributes_parse simple-web-server)
add_executable(request_message_parse fuzzers/request_message_parse.cpp)
target_compile_options(request_message_parse PRIVATE -fsanitize=address,fuzzer)
target_link_options(request_message_parse PRIVATE -fsanitize=address,fuzzer)
target_link_libraries(request_message_parse simple-web-server)
add_executable(response_message_parse fuzzers/response_message_parse.cpp)
target_compile_options(response_message_parse PRIVATE -fsanitize=address,fuzzer)
target_link_options(response_message_parse PRIVATE -fsanitize=address,fuzzer)
target_link_libraries(response_message_parse simple-web-server)
endif()

6
tests/fuzzers/README.md Normal file
View file

@ -0,0 +1,6 @@
Prior to running the fuzzers, build and prepare for instance as follows:
```sh
CXX=clang++ cmake -DBUILD_FUZZING=1 ..
make
export LSAN_OPTIONS=detect_leaks=0
```

View file

@ -0,0 +1,6 @@
#include "utility.hpp"
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
SimpleWeb::HttpHeader::FieldValue::SemicolonSeparatedAttributes::parse(std::string(reinterpret_cast<const char *>(data), size));
return 0;
}

View file

@ -0,0 +1,9 @@
#include "utility.hpp"
#include <sstream>
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
std::stringstream ss;
ss << std::string(reinterpret_cast<const char *>(data), size);
SimpleWeb::HttpHeader::parse(ss);
return 0;
}

View file

@ -0,0 +1,6 @@
#include "utility.hpp"
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
SimpleWeb::Percent::decode(std::string(reinterpret_cast<const char *>(data), size));
return 0;
}

View file

@ -0,0 +1,6 @@
#include "utility.hpp"
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
SimpleWeb::QueryString::parse(std::string(reinterpret_cast<const char *>(data), size));
return 0;
}

View file

@ -0,0 +1,11 @@
#include "utility.hpp"
#include <sstream>
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
std::stringstream ss;
ss << std::string(reinterpret_cast<const char *>(data), size);
std::string method, path, query_string, version;
SimpleWeb::CaseInsensitiveMultimap header;
SimpleWeb::RequestMessage::parse(ss, method, path, query_string, version, header);
return 0;
}

View file

@ -0,0 +1,11 @@
#include "utility.hpp"
#include <sstream>
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
std::stringstream ss;
ss << std::string(reinterpret_cast<const char *>(data), size);
std::string version, status_code;
SimpleWeb::CaseInsensitiveMultimap header;
SimpleWeb::ResponseMessage::parse(ss, version, status_code, header);
return 0;
}