Coverage Report

Created: 2023-03-26 06:57

/src/boost/libs/json/fuzzing/fuzz_parse.cpp
Line
Count
Source (jump to first uncovered line)
1
//
2
// Copyright (c) 2019 Vinnie Falco (vinnie.falco@gmail.com)
3
// Copyright (c) 2020 Paul Dreik (github@pauldreik.se)
4
//
5
// Distributed under the Boost Software License, Version 1.0. (See accompanying
6
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
7
//
8
// Official repository: https://github.com/boostorg/json
9
//
10
11
#include <boost/json/parse.hpp>
12
13
using namespace boost::json;
14
15
bool
16
fuzz_parse(string_view sv)
17
6.62k
{
18
6.62k
    error_code ec;
19
6.62k
    value jv = parse( sv, ec );
20
6.62k
    if(ec)
21
4.63k
        return false;
22
1.99k
    return jv.is_number();
23
6.62k
}
24
25
extern "C"
26
int
27
LLVMFuzzerTestOneInput(
28
    const uint8_t* data, size_t size)
29
12.5k
{
30
12.5k
    try
31
12.5k
    {
32
12.5k
        string_view s{reinterpret_cast<
33
12.5k
            const char*>(data), size};
34
12.5k
        fuzz_parse(s);
35
12.5k
    }
36
12.5k
    catch(...)
37
12.5k
    {
38
0
    }
39
12.5k
    return 0;
40
12.5k
}