Coverage Report

Created: 2025-11-24 06:51

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/qpdf/fuzz/runlength_fuzzer.cc
Line
Count
Source
1
#include <qpdf/Pl_Discard.hh>
2
#include <qpdf/Pl_RunLength.hh>
3
#include <iostream>
4
#include <stdexcept>
5
6
class FuzzHelper
7
{
8
  public:
9
    FuzzHelper(unsigned char const* data, size_t size);
10
    void run();
11
12
  private:
13
    void doChecks();
14
15
    unsigned char const* data;
16
    size_t size;
17
};
18
19
FuzzHelper::FuzzHelper(unsigned char const* data, size_t size) :
20
300k
    data(data),
21
300k
    size(size)
22
300k
{
23
300k
}
24
25
void
26
FuzzHelper::doChecks()
27
284k
{
28
284k
    Pl_RunLength::setMemoryLimit(1'000'000);
29
284k
    Pl_Discard discard;
30
284k
    Pl_RunLength p("decode", &discard, Pl_RunLength::a_decode);
31
284k
    p.write(const_cast<unsigned char*>(data), size);
32
284k
    p.finish();
33
284k
}
34
35
void
36
FuzzHelper::run()
37
36.7k
{
38
36.7k
    try {
39
36.7k
        doChecks();
40
36.7k
    } catch (std::runtime_error const& e) {
41
29.7k
        std::cerr << "runtime_error: " << e.what() << '\n';
42
29.7k
    }
43
36.7k
}
44
45
extern "C" int
46
LLVMFuzzerTestOneInput(unsigned char const* data, size_t size)
47
300k
{
48
300k
    FuzzHelper f(data, size);
49
300k
    f.run();
50
300k
    return 0;
51
300k
}