Coverage Report

Created: 2024-02-25 07:20

/src/libfusn/ossfuzz/record_fuzzer.cc
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * OSS-Fuzz target for libfusn record type
3
 *
4
 * Copyright (C) 2011-2024, Joachim Metz <joachim.metz@gmail.com>
5
 *
6
 * Refer to AUTHORS for acknowledgements.
7
 *
8
 * This program is free software: you can redistribute it and/or modify
9
 * it under the terms of the GNU Lesser General Public License as published by
10
 * the Free Software Foundation, either version 3 of the License, or
11
 * (at your option) any later version.
12
 *
13
 * This program is distributed in the hope that it will be useful,
14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16
 * GNU General Public License for more details.
17
 *
18
 * You should have received a copy of the GNU Lesser General Public License
19
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
20
 */
21
22
#include <stddef.h>
23
#include <stdint.h>
24
25
/* Note that some of the OSS-Fuzz engines use C++
26
 */
27
extern "C" {
28
29
#include "ossfuzz_libfusn.h"
30
31
int LLVMFuzzerTestOneInput(
32
     const uint8_t *data,
33
     size_t size )
34
14.9k
{
35
14.9k
  libfusn_record_t *record = NULL;
36
37
14.9k
  if( libfusn_record_initialize(
38
14.9k
       &record,
39
14.9k
       NULL ) != 1 )
40
0
  {
41
0
    return( 0 );
42
0
  }
43
14.9k
  libfusn_record_copy_from_byte_stream(
44
14.9k
   record,
45
14.9k
   data,
46
14.9k
   size,
47
14.9k
   NULL );
48
49
14.9k
  libfusn_record_free(
50
14.9k
   &record,
51
14.9k
   NULL );
52
53
14.9k
  return( 0 );
54
14.9k
}
55
56
} /* extern "C" */
57