/* __ _____ _____ _____ __| | __| | | | JSON for Modern C++ (fuzz test support) | | |__ | | | | | | version 3.4.0 |_____|_____|_____|_|___| https://github.com/nlohmann/json This file implements a parser test suitable for fuzz testing. Given a byte array data, it performs the following steps: - j1 = from_bson(data) - vec = to_bson(j1) - j2 = from_bson(vec) - assert(j1 == j2) The provided function `LLVMFuzzerTestOneInput` can be used in different fuzzer drivers. Licensed under the MIT License . */ #include #include #include using json = nlohmann::json; // see http://llvm.org/docs/LibFuzzer.html extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { try { // step 1: parse input std::vector vec1(data, data + size); json j1 = json::from_bson(vec1); if (j1.is_discarded()) { return 0; } try { // step 2: round trip std::vector vec2 = json::to_bson(j1); // parse serialization json j2 = json::from_bson(vec2); // serializations must match assert(json::to_bson(j2) == vec2); } catch (const json::parse_error&) { // parsing a BSON serialization must not fail assert(false); } } catch (const json::parse_error&) { // parse errors are ok, because input may be random bytes } catch (const json::type_error&) { // type errors can occur during parsing, too } catch (const json::out_of_range&) { // out of range errors can occur during parsing, too } // return 0 - non-zero return values are reserved for future use return 0; }