mysql/test/fuzzing/fuzz_execute_response.cpp
Ruben Perez cc73a0592f Fuzz testing
close #31
2023-07-07 17:22:54 +02:00

28 lines
941 B
C++

//
// Copyright (c) 2019-2023 Ruben Perez Hidalgo (rubenperez038 at gmail dot com)
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
#include <boost/mysql/diagnostics.hpp>
#include <boost/mysql/impl/internal/protocol/db_flavor.hpp>
#include <boost/mysql/impl/internal/protocol/protocol.hpp>
using namespace boost::mysql::detail;
static bool parse_execute_response(const uint8_t* data, size_t size) noexcept
{
boost::mysql::diagnostics diag;
auto msg = deserialize_execute_response({data, size}, db_flavor::mariadb, diag);
return msg.type == execute_response::type_t::error && diag.server_message().empty();
}
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
{
// Note: this code should never throw exceptions, for any kind of input
parse_execute_response(data, size);
return 0;
}