// RUN: %clangxx -fsanitize=realtime %s -o %t // RUN: env RTSAN_OPTIONS="halt_on_error=false,print_stats_on_exit=true" %run %t 2>&1 | FileCheck %s // RUN: env RTSAN_OPTIONS="halt_on_error=false,suppress_equal_stacks=false" %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-DUPLICATES // UNSUPPORTED: ios // Intent: Ensure all errors are deduplicated. #include const int kNumViolations = 10; void violation() [[clang::nonblocking]] { for (int i = 0; i < kNumViolations; i++) usleep(1); } void violation2() [[clang::nonblocking]] { for (int i = 0; i < kNumViolations; i++) violation(); } void double_violation() [[clang::nonblocking]] { violation(); violation2(); } int main() { violation(); // 1 unique errors here, but 10 total violation2(); // 1 unique errors here, but 100 total double_violation(); // 2 unique errors here, but 110 total return 0; } // CHECK-COUNT-4: ==ERROR: // CHECK-NOT: ==ERROR: // CHECK: RealtimeSanitizer exit stats: // CHECK-NEXT: Total error count: 220 // CHECK-NEXT: Unique error count: 4 // CHECK-DUPLICATES-COUNT-220: ==ERROR: // CHECK-DUPLICATES-NOT: ==ERROR: