blob: a868084a0ceefeefc77a1bd19a58c899308a0d65 [file] [log] [blame]
Aaron Ballmanef116982015-01-29 16:58:29 +00001// Simple test for a fuzzer. The fuzzer must find the string "FUZZER".
2#include <cstdint>
3#include <cstdlib>
4#include <cstddef>
5#include <iostream>
6
Kostya Serebryany20bb5e72015-10-02 23:34:06 +00007extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
Aaron Ballmanef116982015-01-29 16:58:29 +00008 int bits = 0;
9 if (Size > 0 && Data[0] == 'F') bits |= 1;
10 if (Size > 1 && Data[1] == 'U') bits |= 2;
11 if (Size > 2 && Data[2] == 'Z') bits |= 4;
12 if (Size > 3 && Data[3] == 'Z') bits |= 8;
13 if (Size > 4 && Data[4] == 'E') bits |= 16;
14 if (Size > 5 && Data[5] == 'R') bits |= 32;
15 if (bits == 63) {
16 std::cerr << "BINGO!\n";
Kostya Serebryany2c1b33b2015-01-29 23:01:07 +000017 exit(1);
Aaron Ballmanef116982015-01-29 16:58:29 +000018 }
Kostya Serebryany20bb5e72015-10-02 23:34:06 +000019 return 0;
Aaron Ballmanef116982015-01-29 16:58:29 +000020}
21