Coverage Report

Created: 2025-08-29 07:34

/src/PcapPlusPlus/Tests/Fuzzers/DumpToFile.h
Line
Count
Source (jump to first uncovered line)
1
#pragma once
2
3
#include <iostream>
4
5
// This function is created as PcapPlusPlus doesn't seem to offer a way of
6
// parsing Pcap files directly from memory
7
static int dumpDataToPcapFile(const uint8_t* data, size_t size, const char* path)
8
6.00k
{
9
6.00k
  FILE* fd;
10
6.00k
  int written = 0;
11
12
6.00k
  fd = fopen(path, "wb");
13
6.00k
  if (fd == NULL)
14
0
  {
15
0
    std::cerr << "Error opening pcap file for writing\n";
16
0
    return -1;
17
0
  }
18
19
6.00k
  written = fwrite(data, 1, size, fd);
20
6.00k
  if (static_cast<size_t>(written) != size)
21
0
  {
22
0
    std::cerr << "Error writing pcap file\n";
23
0
    fclose(fd);
24
0
    return -1;
25
0
  }
26
27
6.00k
  fclose(fd);
28
6.00k
  return 0;
29
6.00k
}
FuzzTarget.cpp:dumpDataToPcapFile(unsigned char const*, unsigned long, char const*)
Line
Count
Source
8
219
{
9
219
  FILE* fd;
10
219
  int written = 0;
11
12
219
  fd = fopen(path, "wb");
13
219
  if (fd == NULL)
14
0
  {
15
0
    std::cerr << "Error opening pcap file for writing\n";
16
0
    return -1;
17
0
  }
18
19
219
  written = fwrite(data, 1, size, fd);
20
219
  if (static_cast<size_t>(written) != size)
21
0
  {
22
0
    std::cerr << "Error writing pcap file\n";
23
0
    fclose(fd);
24
0
    return -1;
25
0
  }
26
27
219
  fclose(fd);
28
219
  return 0;
29
219
}
FuzzWriter.cpp:dumpDataToPcapFile(unsigned char const*, unsigned long, char const*)
Line
Count
Source
8
5.79k
{
9
5.79k
  FILE* fd;
10
5.79k
  int written = 0;
11
12
5.79k
  fd = fopen(path, "wb");
13
5.79k
  if (fd == NULL)
14
0
  {
15
0
    std::cerr << "Error opening pcap file for writing\n";
16
0
    return -1;
17
0
  }
18
19
5.79k
  written = fwrite(data, 1, size, fd);
20
5.79k
  if (static_cast<size_t>(written) != size)
21
0
  {
22
0
    std::cerr << "Error writing pcap file\n";
23
0
    fclose(fd);
24
0
    return -1;
25
0
  }
26
27
5.79k
  fclose(fd);
28
5.79k
  return 0;
29
5.79k
}