aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2021-12-09 11:55:36 +0100
committerGitHub <noreply@github.com>2021-12-09 11:55:36 +0100
commit08ca4d54a55fe73e64a994c41a12af61f52e497e (patch)
tree2d0f060cf98afbe80f5bf810fd6b167a5152be81 /test
parent773baf9391ff5f1793deb7968366819e7fa07adc (diff)
parent4c6d94ea5f854071277ed9729de2d4ef7d07cc84 (diff)
downloadafl++-08ca4d54a55fe73e64a994c41a12af61f52e497e.tar.gz
Merge pull request #1101 from AFLplusplus/dev
Dev
Diffstat (limited to 'test')
-rw-r--r--test/test-cmplog.c21
-rw-r--r--test/test-dlopen.c20
-rwxr-xr-xtest/test-pre.sh2
3 files changed, 35 insertions, 8 deletions
diff --git a/test/test-cmplog.c b/test/test-cmplog.c
index b077e3ab..262df6bd 100644
--- a/test/test-cmplog.c
+++ b/test/test-cmplog.c
@@ -1,15 +1,13 @@
#include <stdio.h>
#include <string.h>
+#include <stdint.h>
#include <stdarg.h>
#include <stdlib.h>
#include <stdint.h>
#include <unistd.h>
-int main(int argc, char *argv[]) {
- char buf[1024];
- ssize_t i;
- if ((i = read(0, buf, sizeof(buf) - 1)) < 24) return 0;
- buf[i] = 0;
+int LLVMFuzzerTestOneInput(const uint8_t *buf, size_t i) {
+ if (i < 24) return 0;
if (buf[0] != 'A') return 0;
if (buf[1] != 'B') return 0;
if (buf[2] != 'C') return 0;
@@ -18,6 +16,17 @@ int main(int argc, char *argv[]) {
if (strncmp(buf + 12, "IJKL", 4) == 0 && strcmp(buf + 16, "DEADBEEF") == 0)
abort();
return 0;
-
}
+#ifdef __AFL_COMPILER
+int main(int argc, char *argv[]) {
+ unsigned char buf[1024];
+ ssize_t i;
+ while(__AFL_LOOP(1000)) {
+ i = read(0, (char*)buf, sizeof(buf) - 1);
+ if (i > 0) buf[i] = 0;
+ LLVMFuzzerTestOneInput(buf, i);
+ }
+ return 0;
+}
+#endif
diff --git a/test/test-dlopen.c b/test/test-dlopen.c
index d08d9092..b81bab13 100644
--- a/test/test-dlopen.c
+++ b/test/test-dlopen.c
@@ -5,7 +5,13 @@
int main(int argc, char **argv) {
- if (!getenv("TEST_DLOPEN_TARGET")) return 1;
+ if (!getenv("TEST_DLOPEN_TARGET")) {
+
+ fprintf(stderr, "Error: TEST_DLOPEN_TARGET not set!\n");
+ return 1;
+
+ }
+
void *lib = dlopen(getenv("TEST_DLOPEN_TARGET"), RTLD_LAZY);
if (!lib) {
@@ -15,8 +21,18 @@ int main(int argc, char **argv) {
}
int (*func)(int, char **) = dlsym(lib, "main_exported");
- if (!func) return 3;
+ if (!func) {
+
+ fprintf(stderr, "Error: main_exported not found!\n");
+ return 3;
+
+ }
+
+ // must use deferred forkserver as otherwise afl++ instrumentation aborts
+ // because all dlopen() of instrumented libs must be before the forkserver
+ __AFL_INIT();
+ fprintf(stderr, "Running main_exported\n");
return func(argc, argv);
}
diff --git a/test/test-pre.sh b/test/test-pre.sh
index 7819da47..e12d95be 100755
--- a/test/test-pre.sh
+++ b/test/test-pre.sh
@@ -88,6 +88,8 @@ unset AFL_QEMU_PERSISTENT_GPR
unset AFL_QEMU_PERSISTENT_RET
unset AFL_QEMU_PERSISTENT_HOOK
unset AFL_QEMU_PERSISTENT_CNT
+unset AFL_QEMU_PERSISTENT_MEM
+unset AFL_QEMU_PERSISTENT_EXITS
unset AFL_CUSTOM_MUTATOR_LIBRARY
unset AFL_PYTHON_MODULE
unset AFL_PRELOAD