Coverage Report

Created: 2026-06-05 07:06

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/igraph/fuzzing/centrality.cpp
Line
Count
Source
1
/*
2
   igraph library.
3
   Copyright (C) 2024  The igraph development team
4
5
   This program is free software; you can redistribute it and/or modify
6
   it under the terms of the GNU General Public License as published by
7
   the Free Software Foundation; either version 2 of the License, or
8
   (at your option) any later version.
9
10
   This program is distributed in the hope that it will be useful,
11
   but WITHOUT ANY WARRANTY; without even the implied warranty of
12
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
   GNU General Public License for more details.
14
15
   You should have received a copy of the GNU General Public License
16
   along with this program; if not, write to the Free Software
17
   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
18
   02110-1301 USA
19
*/
20
21
#include <igraph.h>
22
#include <cstdlib>
23
24
const igraph_real_t eps = 1e-10;
25
26
14.5k
bool vector_isininterval_eps(const igraph_vector_t *v, igraph_real_t lo, igraph_real_t hi) {
27
14.5k
    const igraph_int_t n = igraph_vector_size(v);
28
29
531k
    for (igraph_int_t i=0; i < n; i++) {
30
517k
        igraph_real_t x = VECTOR(*v)[i];
31
517k
        if (igraph_cmp_epsilon(lo, x, eps) > 0 || igraph_cmp_epsilon(x, hi, eps) > 0) {
32
0
            return false;
33
0
        }
34
517k
    }
35
36
14.5k
    return true;
37
14.5k
}
38
39
1.48k
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
40
1.48k
    igraph_t graph;
41
1.48k
    igraph_vector_int_t edges;
42
43
1.48k
    igraph_set_warning_handler(igraph_warning_handler_ignore);
44
45
1.48k
    if (Size % 2 == 0 || Size > 512+1 || Size < 1) {
46
14
        return 0;
47
14
    }
48
49
1.46k
    igraph_vector_int_init(&edges, Size-1);
50
86.2k
    for (size_t i=0; i < Size-1; ++i) {
51
84.7k
        VECTOR(edges)[i] = Data[i+1];
52
84.7k
    }
53
54
1.46k
    igraph_rng_seed(igraph_rng_default(), 42);
55
56
1.46k
    if (igraph_create(&graph, &edges, Data[0], IGRAPH_DIRECTED) == IGRAPH_SUCCESS) {
57
1.46k
        const igraph_int_t vcount = igraph_vcount(&graph);
58
1.46k
        igraph_vector_t v, v2;
59
1.46k
        igraph_vector_int_t iv;
60
1.46k
        igraph_bool_t b;
61
1.46k
        igraph_real_t r;
62
63
        /* Limit graph size for the sake of performance. */
64
1.46k
        if (vcount <= 64) {
65
1.42k
            igraph_vector_init(&v, 0);
66
1.42k
            igraph_vector_init(&v2, 0);
67
1.42k
            igraph_vector_int_init(&iv, 0);
68
69
1.42k
            igraph_betweenness(&graph, NULL, &v2, igraph_vss_all(), IGRAPH_UNDIRECTED, false);
70
1.42k
            IGRAPH_ASSERT(vector_isininterval_eps(&v2, 0, vcount == 0 ? 0 : (vcount-1)*(vcount-2)/2));
71
72
1.42k
            igraph_betweenness_cutoff(&graph, NULL, &v, igraph_vss_all(), IGRAPH_UNDIRECTED, false, 4);
73
1.42k
            IGRAPH_ASSERT(vector_isininterval_eps(&v, 0, vcount == 0 ? 0 : (vcount-1)*(vcount-2)/2));
74
1.42k
            IGRAPH_ASSERT(igraph_vector_all_le(&v, &v2));
75
76
1.42k
            igraph_betweenness(&graph, NULL, &v2, igraph_vss_all(), IGRAPH_DIRECTED, false);
77
1.42k
            IGRAPH_ASSERT(vector_isininterval_eps(&v2, 0, vcount == 0 ? 0 : (vcount-1)*(vcount-2)));
78
79
1.42k
            igraph_betweenness_cutoff(&graph, NULL, &v, igraph_vss_all(), IGRAPH_DIRECTED, false, 5);
80
1.42k
            IGRAPH_ASSERT(vector_isininterval_eps(&v, 0, vcount == 0 ? 0 : (vcount-1)*(vcount-2)));
81
1.42k
            IGRAPH_ASSERT(igraph_vector_all_le(&v, &v2));
82
83
1.42k
            igraph_edge_betweenness(&graph, NULL, &v2, igraph_ess_all(IGRAPH_EDGEORDER_ID), IGRAPH_DIRECTED, false);
84
1.42k
            IGRAPH_ASSERT(vector_isininterval_eps(&v2, 0, vcount*(vcount-1)/2));
85
86
1.42k
            igraph_edge_betweenness_cutoff(&graph, NULL, &v, igraph_ess_all(IGRAPH_EDGEORDER_ID), IGRAPH_DIRECTED,
87
1.42k
                                           false, 4);
88
1.42k
            IGRAPH_ASSERT(vector_isininterval_eps(&v, 0, vcount*(vcount-1)/2));
89
1.42k
            IGRAPH_ASSERT(igraph_vector_all_le(&v, &v2));
90
91
1.42k
            igraph_edge_betweenness(&graph, NULL, &v2, igraph_ess_all(IGRAPH_EDGEORDER_ID), IGRAPH_UNDIRECTED, false);
92
1.42k
            IGRAPH_ASSERT(vector_isininterval_eps(&v2, 0, vcount*(vcount-1)));
93
94
1.42k
            igraph_edge_betweenness_cutoff(&graph, NULL, &v, igraph_ess_all(IGRAPH_EDGEORDER_ID), IGRAPH_UNDIRECTED,
95
1.42k
                                           false, 3);
96
1.42k
            IGRAPH_ASSERT(vector_isininterval_eps(&v, 0, vcount*(vcount-1)));
97
1.42k
            IGRAPH_ASSERT(igraph_vector_all_le(&v, &v2));
98
99
1.42k
            if (vcount >= 10) {
100
1.29k
                igraph_betweenness_subset(&graph, NULL, &v,
101
1.29k
                                          igraph_vss_range(0,5), igraph_vss_range(5,10),
102
1.29k
                                          igraph_vss_all(), IGRAPH_DIRECTED, false);
103
1.29k
                igraph_edge_betweenness_subset(&graph, NULL, &v,
104
1.29k
                                               igraph_vss_range(0,10), igraph_vss_range(0,10),
105
1.29k
                                               igraph_ess_all(IGRAPH_EDGEORDER_ID), IGRAPH_DIRECTED, false);
106
1.29k
            }
107
1.42k
            igraph_closeness_cutoff(&graph, &v, &iv, &b, igraph_vss_all(), IGRAPH_ALL, NULL, true, 3);
108
1.42k
            igraph_closeness_cutoff(&graph, &v, &iv, &b, igraph_vss_all(), IGRAPH_OUT, NULL, true, 4);
109
1.42k
            igraph_harmonic_centrality_cutoff(&graph, &v, igraph_vss_all(), IGRAPH_ALL, NULL, true, 3);
110
1.42k
            igraph_harmonic_centrality_cutoff(&graph, &v, igraph_vss_all(), IGRAPH_IN, NULL, true, 4);
111
1.42k
            igraph_global_efficiency(&graph, NULL, &r, IGRAPH_DIRECTED);
112
1.42k
            igraph_local_efficiency(&graph, NULL, &v, igraph_vss_all(), IGRAPH_DIRECTED, IGRAPH_OUT);
113
1.42k
            igraph_transitivity_undirected(&graph, &r, IGRAPH_TRANSITIVITY_NAN);
114
1.42k
            igraph_transitivity_local_undirected(&graph, &v, igraph_vss_all(), IGRAPH_TRANSITIVITY_NAN);
115
1.42k
            igraph_transitivity_avglocal_undirected(&graph, &r, IGRAPH_TRANSITIVITY_ZERO);
116
1.42k
            igraph_count_adjacent_triangles(&graph, &v, igraph_vss_all());
117
118
1.42k
            igraph_pagerank(&graph, NULL, &v, &r, 0.6, IGRAPH_DIRECTED, igraph_vss_all(), IGRAPH_PAGERANK_ALGO_PRPACK,
119
1.42k
                            NULL);
120
1.42k
            IGRAPH_ASSERT(vcount == 0 || igraph_almost_equals(igraph_vector_sum(&v), 1.0, 1e-10));
121
122
1.42k
            igraph_constraint(&graph, &v, igraph_vss_all(), NULL);
123
1.42k
            igraph_spanner(&graph, &iv, 2.34, NULL);
124
125
1.42k
            igraph_to_undirected(&graph, IGRAPH_TO_UNDIRECTED_COLLAPSE, NULL);
126
1.42k
            igraph_simplify(&graph, /* remove_multiple */ true, /* remove_loops */ false, NULL);
127
1.42k
            igraph_trussness(&graph, &iv);
128
129
1.42k
            igraph_vector_int_destroy(&iv);
130
1.42k
            igraph_vector_destroy(&v2);
131
1.42k
            igraph_vector_destroy(&v);
132
1.42k
        }
133
134
1.46k
        igraph_destroy(&graph);
135
1.46k
    }
136
137
1.46k
    igraph_vector_int_destroy(&edges);
138
139
1.46k
    IGRAPH_ASSERT(IGRAPH_FINALLY_STACK_EMPTY);
140
141
1.46k
    return 0;  // Non-zero return values are reserved for future use.
142
1.46k
}