Coverage Report

Created: 2026-06-15 06:04

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/immer/extra/fuzzer/vector-gc.cpp
Line
Count
Source
1
//
2
// immer: immutable data structures for C++
3
// Copyright (C) 2016, 2017, 2018 Juan Pedro Bolivar Puente
4
//
5
// This software is distributed under the Boost Software License, Version 1.0.
6
// See accompanying file LICENSE or copy at http://boost.org/LICENSE_1_0.txt
7
//
8
9
#include "fuzzer_input.hpp"
10
11
#include <immer/heap/gc_heap.hpp>
12
#include <immer/refcount/no_refcount_policy.hpp>
13
#include <immer/vector.hpp>
14
#include <immer/vector_transient.hpp>
15
16
#include <array>
17
18
using gc_memory = immer::memory_policy<immer::heap_policy<immer::gc_heap>,
19
                                       immer::no_refcount_policy,
20
                                       immer::default_lock_policy,
21
                                       immer::gc_transience_policy,
22
                                       false>;
23
24
extern "C" int LLVMFuzzerTestOneInput(const std::uint8_t* data,
25
                                      std::size_t size)
26
84.9k
{
27
84.9k
    auto guard = immer::gc_disable_guard{};
28
29
84.9k
    constexpr auto var_count = 4;
30
84.9k
    constexpr auto bits      = 2;
31
32
84.9k
    using vector_t    = immer::vector<int, gc_memory, bits, bits>;
33
84.9k
    using transient_t = typename vector_t::transient_type;
34
84.9k
    using size_t      = std::uint8_t;
35
36
84.9k
    auto vs = std::array<vector_t, var_count>{};
37
84.9k
    auto ts = std::array<transient_t, var_count>{};
38
39
2.25M
    auto is_valid_var   = [&](auto idx) { return idx >= 0 && idx < var_count; };
40
84.9k
    auto is_valid_index = [](auto& v) {
41
41.2k
        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
vector-gc.cpp:auto LLVMFuzzerTestOneInput::$_1::operator()<immer::vector<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u> >(immer::vector<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u>&) const::{lambda(auto:1)#1}::operator()<unsigned char>(unsigned char) const
Line
Count
Source
41
15.8k
        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
vector-gc.cpp:auto LLVMFuzzerTestOneInput::$_1::operator()<immer::vector_transient<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u> >(immer::vector_transient<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u>&) const::{lambda(auto:1)#1}::operator()<unsigned char>(unsigned char) const
Line
Count
Source
41
25.4k
        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
42
29.4k
    };
vector-gc.cpp:auto LLVMFuzzerTestOneInput::$_1::operator()<immer::vector<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u> >(immer::vector<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u>&) const
Line
Count
Source
40
7.16k
    auto is_valid_index = [](auto& v) {
41
7.16k
        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
42
7.16k
    };
vector-gc.cpp:auto LLVMFuzzerTestOneInput::$_1::operator()<immer::vector_transient<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u> >(immer::vector_transient<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u>&) const
Line
Count
Source
40
22.3k
    auto is_valid_index = [](auto& v) {
41
22.3k
        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
42
22.3k
    };
43
84.9k
    auto is_valid_size = [](auto& v) {
44
88.2k
        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
vector-gc.cpp:auto LLVMFuzzerTestOneInput::$_2::operator()<immer::vector<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u> >(immer::vector<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u>&) const::{lambda(auto:1)#1}::operator()<unsigned char>(unsigned char) const
Line
Count
Source
44
30.2k
        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
vector-gc.cpp:auto LLVMFuzzerTestOneInput::$_2::operator()<immer::vector_transient<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u> >(immer::vector_transient<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u>&) const::{lambda(auto:1)#1}::operator()<unsigned char>(unsigned char) const
Line
Count
Source
44
57.9k
        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
45
68.6k
    };
vector-gc.cpp:auto LLVMFuzzerTestOneInput::$_2::operator()<immer::vector<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u> >(immer::vector<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u>&) const
Line
Count
Source
43
26.4k
    auto is_valid_size = [](auto& v) {
44
26.4k
        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
45
26.4k
    };
vector-gc.cpp:auto LLVMFuzzerTestOneInput::$_2::operator()<immer::vector_transient<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u> >(immer::vector_transient<int, immer::memory_policy<immer::heap_policy<immer::gc_heap>, immer::no_refcount_policy, immer::spinlock_policy, immer::gc_transience_policy, false, false>, 2u, 2u>&) const
Line
Count
Source
43
42.2k
    auto is_valid_size = [](auto& v) {
44
42.2k
        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
45
42.2k
    };
46
47
1.94M
    return fuzzer_input{data, size}.run([&](auto& in) {
48
1.94M
        enum ops
49
1.94M
        {
50
1.94M
            op_transient,
51
1.94M
            op_persistent,
52
1.94M
            op_push_back,
53
1.94M
            op_update,
54
1.94M
            op_take,
55
1.94M
            op_push_back_mut,
56
1.94M
            op_update_mut,
57
1.94M
            op_take_mut,
58
1.94M
        };
59
1.94M
        auto dst = read<char>(in, is_valid_var);
60
1.94M
        switch (read<char>(in)) {
61
66.5k
        case op_transient: {
62
66.5k
            auto src = read<char>(in, is_valid_var);
63
66.5k
            ts[dst]  = vs[src].transient();
64
66.5k
            break;
65
0
        }
66
10.0k
        case op_persistent: {
67
10.0k
            auto src = read<char>(in, is_valid_var);
68
10.0k
            vs[dst]  = ts[src].persistent();
69
10.0k
            break;
70
0
        }
71
5.70k
        case op_push_back: {
72
5.70k
            auto src = read<char>(in, is_valid_var);
73
5.70k
            vs[dst]  = vs[src].push_back(42);
74
5.70k
            break;
75
0
        }
76
7.20k
        case op_update: {
77
7.20k
            auto src = read<char>(in, is_valid_var);
78
7.20k
            auto idx = read<size_t>(in, is_valid_index(vs[src]));
79
7.20k
            vs[dst]  = vs[src].update(idx, [](auto x) { return x + 1; });
80
7.20k
            break;
81
0
        }
82
26.4k
        case op_take: {
83
26.4k
            auto src = read<char>(in, is_valid_var);
84
26.4k
            auto idx = read<size_t>(in, is_valid_size(vs[src]));
85
26.4k
            vs[dst]  = vs[src].take(idx);
86
26.4k
            break;
87
0
        }
88
1.75M
        case op_push_back_mut: {
89
1.75M
            ts[dst].push_back(13);
90
1.75M
            break;
91
0
        }
92
22.3k
        case op_update_mut: {
93
22.3k
            auto idx = read<size_t>(in, is_valid_index(ts[dst]));
94
22.3k
            ts[dst].update(idx, [](auto x) { return x + 1; });
95
22.3k
            break;
96
0
        }
97
42.2k
        case op_take_mut: {
98
42.2k
            auto idx = read<size_t>(in, is_valid_size(ts[dst]));
99
42.2k
            ts[dst].take(idx);
100
42.2k
            break;
101
0
        }
102
12.2k
        default:
103
12.2k
            break;
104
1.94M
        };
105
1.94M
        return true;
106
1.94M
    });
107
84.9k
}