File: asan_log_to_crashreporter.cpp

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (29 lines) | stat: -rw-r--r-- 1,189 bytes parent folder | download | duplicates (26)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
// UNSUPPORTED: ios
// We can reduce the scope of this test to check that we set the crash reporter
// buffers correctly instead of reading from the crashlog.
// For now, disable this test.
// REQUIRES: rdar_74544282
// REQUIRES: expensive
// Check that ASan reports on OS X actually crash the process (abort_on_error=1)
// and that crash is logged via the crash reporter with ASan logs in the
// Application Specific Information section of the log.

// RUN: %clangxx_asan %s -o %t

// crash hard so the crashlog is created.
// RUN: %env_asan_opts=abort_on_error=1 not --crash %run %t > %t.process_output.txt 2>&1
// RUN: %print_crashreport_for_pid --binary-filename=%basename_t.tmp \
// RUN: --pid=$(%get_pid_from_output --infile=%t.process_output.txt) \
// RUN: | FileCheck %s --check-prefixes CHECK-CRASHLOG

#include <stdlib.h>
int main() {
  char *x = (char *)malloc(10 * sizeof(char));
  free(x);
  return x[5];
  // needs to crash hard so the crashlog exists...
  // CHECK-CRASHLOG: {{.*Application Specific Information:}}
  // CHECK-CRASHLOG-NEXT: {{=====}}
  // CHECK-CRASHLOG-NEXT: {{.*ERROR: AddressSanitizer: heap-use-after-free on address}}
  // CHECK-CRASHLOG: {{abort()}}
}