aboutsummaryrefslogtreecommitdiff
path: root/test/fuzzing/main.cc
blob: 8f8c719b7263ec5328f9277cf53efd0156f51ef7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <cassert>
#include <fstream>
#include <vector>

#include "fuzzer-common.h"

extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size);

int main(int argc, char** argv) {
  for (int i = 1; i < argc; ++i) {
    std::ifstream in(argv[i]);
    assert(in);
    in.seekg(0, std::ios_base::end);
    const auto size = in.tellg();
    assert(size >= 0);
    in.seekg(0, std::ios_base::beg);
    std::vector<char> buf(static_cast<size_t>(size));
    in.read(buf.data(), size);
    assert(in.gcount() == size);
    LLVMFuzzerTestOneInput(as_bytes(buf.data()), buf.size());
  }
}