Coverage Report

Created: 2026-05-16 07:02

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/strongswan/fuzz/fuzz_certs.c
Line
Count
Source
1
/*
2
 * Copyright (C) 2017 Tobias Brunner
3
 *
4
 * Copyright (C) secunet Security Networks AG
5
 *
6
 * This program is free software; you can redistribute it and/or modify it
7
 * under the terms of the GNU General Public License as published by the
8
 * Free Software Foundation; either version 2 of the License, or (at your
9
 * option) any later version.  See <http://www.fsf.org/copyleft/gpl.txt>.
10
 *
11
 * This program is distributed in the hope that it will be useful, but
12
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14
 * for more details.
15
 */
16
17
#include <library.h>
18
#include <utils/debug.h>
19
20
int LLVMFuzzerTestOneInput(const uint8_t *buf, size_t len)
21
3.97k
{
22
3.97k
  certificate_t *cert;
23
3.97k
  chunk_t chunk;
24
25
3.97k
  dbg_default_set_level(-1);
26
3.97k
  library_init(NULL, "fuzz_certs");
27
3.97k
  if (!lib->plugins->load(lib->plugins, PLUGINS))
28
0
  {
29
0
    return 1;
30
0
  }
31
32
3.97k
  chunk = chunk_create((u_char*)buf, len);
33
3.97k
  cert = lib->creds->create(lib->creds, CRED_CERTIFICATE, CERT_X509,
34
3.97k
                BUILD_BLOB, chunk, BUILD_END);
35
3.97k
  DESTROY_IF(cert);
36
37
3.97k
  lib->plugins->unload(lib->plugins);
38
3.97k
  library_deinit();
39
3.97k
  return 0;
40
3.97k
}