[libFuzzer] one more test

llvm-svn: 282127
This commit is contained in:
Kostya Serebryany 2016-09-22 00:57:29 +00:00
parent a48055cee3
commit c9e3de35ed
3 changed files with 30 additions and 0 deletions

View File

@ -80,6 +80,7 @@ set(Tests
LeakTest
LeakTimeoutTest
LoadTest
MinimizeCorpusTest
NullDerefTest
NullDerefOnEmptyTest
NthRunCrashTest

View File

@ -0,0 +1,28 @@
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
// Test that we can find the minimal item in the corpus (3 bytes: "FUZ").
#include <cstdint>
#include <cstdlib>
#include <cstddef>
#include <cstring>
#include <cstdio>
static volatile int Sink;
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) {
int8_t Ids[256];
memset(Ids, -1, sizeof(Ids));
for (size_t i = 0; i < Size; i++)
if (Ids[Data[i]] == -1)
Ids[Data[i]] = i;
int F = Ids[(unsigned char)'F'];
int U = Ids[(unsigned char)'U'];
int Z = Ids[(unsigned char)'Z'];
if (F >= 0 && U > F && Z > U) {
Sink++;
// printf("IDS: %d %d %d\n", F, U, Z);
}
return 0;
}

View File

@ -8,6 +8,7 @@ set(TracePCTests
CounterTest
CallerCalleeTest
NullDerefTest
MinimizeCorpusTest
)
foreach(Test ${TracePCTests})