2017-08-22 07:25:50 +08:00
|
|
|
REQUIRES: lsan
|
2018-03-24 07:35:28 +08:00
|
|
|
|
2018-03-28 00:40:20 +08:00
|
|
|
RUN: %cpp_compiler %S/LeakTest.cpp -o %t-LeakTest
|
|
|
|
RUN: %cpp_compiler %S/ThreadedLeakTest.cpp -o %t-ThreadedLeakTest
|
2017-08-22 07:25:50 +08:00
|
|
|
RUN: %cpp_compiler %S/LeakTimeoutTest.cpp -o %t-LeakTimeoutTest
|
|
|
|
|
2017-11-10 04:44:08 +08:00
|
|
|
RUN: rm -rf %t-corpus && mkdir -p %t-corpus
|
2018-05-12 05:29:51 +08:00
|
|
|
RUN: not %run %t-LeakTest -runs=100000 -detect_leaks=1 %t-corpus 2>&1 | FileCheck %s --check-prefix=LEAK_DURING
|
2017-08-22 07:25:50 +08:00
|
|
|
LEAK_DURING: ERROR: LeakSanitizer: detected memory leaks
|
|
|
|
LEAK_DURING: Direct leak of 4 byte(s) in 1 object(s) allocated from:
|
|
|
|
LEAK_DURING: INFO: to ignore leaks on libFuzzer side use -detect_leaks=0
|
|
|
|
LEAK_DURING: Test unit written to ./leak-
|
|
|
|
LEAK_DURING-NOT: DONE
|
|
|
|
LEAK_DURING-NOT: Done
|
|
|
|
|
2017-11-10 04:44:08 +08:00
|
|
|
// Verify leaking input was not added to corpus
|
2018-05-12 05:29:51 +08:00
|
|
|
RUN: %run %t-LeakTest -runs=0 %t-corpus
|
2017-11-10 04:44:08 +08:00
|
|
|
|
2018-05-12 05:29:51 +08:00
|
|
|
RUN: not %run %t-LeakTest -runs=0 -detect_leaks=1 %S 2>&1 | FileCheck %s --check-prefix=LEAK_IN_CORPUS
|
2017-08-22 07:25:50 +08:00
|
|
|
LEAK_IN_CORPUS: ERROR: LeakSanitizer: detected memory leaks
|
|
|
|
LEAK_IN_CORPUS: INFO: a leak has been found in the initial corpus.
|
|
|
|
|
2018-05-12 05:29:51 +08:00
|
|
|
RUN: not %run %t-LeakTest -runs=100000000 %S/hi.txt 2>&1 | FileCheck %s --check-prefix=MULTI_RUN_LEAK
|
2017-08-22 07:25:50 +08:00
|
|
|
MULTI_RUN_LEAK-NOT: pulse
|
|
|
|
MULTI_RUN_LEAK: LeakSanitizer: detected memory leaks
|
|
|
|
|
2018-05-12 05:29:51 +08:00
|
|
|
RUN: not %run %t-LeakTest -runs=100000 -detect_leaks=0 2>&1 | FileCheck %s --check-prefix=LEAK_AFTER
|
|
|
|
RUN: not %run %t-LeakTest -runs=100000 2>&1 | FileCheck %s --check-prefix=LEAK_DURING
|
|
|
|
RUN: not %run %t-ThreadedLeakTest -runs=100000 -detect_leaks=0 2>&1 | FileCheck %s --check-prefix=LEAK_AFTER
|
|
|
|
RUN: not %run %t-ThreadedLeakTest -runs=100000 2>&1 | FileCheck %s --check-prefix=LEAK_DURING
|
2017-08-22 07:25:50 +08:00
|
|
|
LEAK_AFTER: Done 100000 runs in
|
|
|
|
LEAK_AFTER: ERROR: LeakSanitizer: detected memory leaks
|
|
|
|
|
2018-05-12 05:29:51 +08:00
|
|
|
RUN: not %run %t-LeakTest -runs=100000 -max_len=1 2>&1 | FileCheck %s --check-prefix=MAX_LEN_1
|
2017-08-22 07:25:50 +08:00
|
|
|
MAX_LEN_1: Test unit written to ./leak-7cf184f4c67ad58283ecb19349720b0cae756829
|
|
|
|
|
2018-05-12 05:29:51 +08:00
|
|
|
RUN: not %run %t-LeakTimeoutTest -timeout=1 2>&1 | FileCheck %s --check-prefix=LEAK_TIMEOUT
|
2017-08-22 07:25:50 +08:00
|
|
|
LEAK_TIMEOUT: ERROR: libFuzzer: timeout after
|
|
|
|
LEAK_TIMEOUT-NOT: LeakSanitizer
|
|
|
|
|
|
|
|
|
2018-05-12 05:29:51 +08:00
|
|
|
RUN: %run %t-LeakTest -error_exitcode=0
|