1*67e74705SXin Li// RUN: rm -rf %t 2*67e74705SXin Li// RUN: mkdir -p %t/i %t/m %t 3*67e74705SXin Li 4*67e74705SXin Li// RUN: not env FORCE_CLANG_DIAGNOSTICS_CRASH= TMPDIR=%t TEMP=%t TMP=%t \ 5*67e74705SXin Li// RUN: %clang -fsyntax-only %s -I %S/Inputs/module -isysroot %/t/i/ \ 6*67e74705SXin Li// RUN: -fmodules -fmodules-cache-path=%t/m/ -DFOO=BAR 2>&1 | FileCheck %s 7*67e74705SXin Li 8*67e74705SXin Li// RUN: FileCheck --check-prefix=CHECKSRC %s -input-file %t/crash-report-*.m 9*67e74705SXin Li// RUN: FileCheck --check-prefix=CHECKSH %s -input-file %t/crash-report-*.sh 10*67e74705SXin Li// REQUIRES: crash-recovery 11*67e74705SXin Li 12*67e74705SXin Li// because of the glob (*.m, *.sh) 13*67e74705SXin Li// REQUIRES: shell 14*67e74705SXin Li 15*67e74705SXin Li// FIXME: This XFAIL is cargo-culted from crash-report.c. Do we need it? 16*67e74705SXin Li// XFAIL: mingw32 17*67e74705SXin Li 18*67e74705SXin Li@import simple; 19*67e74705SXin Liconst int x = MODULE_MACRO; 20*67e74705SXin Li 21*67e74705SXin Li// CHECK: Preprocessed source(s) and associated run script(s) are located at: 22*67e74705SXin Li// CHECK-NEXT: note: diagnostic msg: {{.*}}.m 23*67e74705SXin Li// CHECK-NEXT: note: diagnostic msg: {{.*}}.cache 24*67e74705SXin Li 25*67e74705SXin Li// CHECKSRC: @import simple; 26*67e74705SXin Li// CHECKSRC: const int x = 10; 27*67e74705SXin Li 28*67e74705SXin Li// CHECKSH: # Crash reproducer 29*67e74705SXin Li// CHECKSH-NEXT: # Driver args: "-fsyntax-only" 30*67e74705SXin Li// CHECKSH-SAME: "-D" "FOO=BAR" 31*67e74705SXin Li// CHECKSH-NEXT: # Original command: {{.*$}} 32*67e74705SXin Li// CHECKSH-NEXT: "-cc1" 33*67e74705SXin Li// CHECKSH: "-isysroot" "{{[^"]*}}/i/" 34*67e74705SXin Li// CHECKSH: "-D" "FOO=BAR" 35*67e74705SXin Li// CHECKSH-NOT: "-fmodules-cache-path=" 36*67e74705SXin Li// CHECKSH: "crash-report-modules-{{[^ ]*}}.m" 37*67e74705SXin Li// CHECKSH: "-ivfsoverlay" "crash-report-modules-{{[^ ]*}}.cache/vfs/vfs.yaml" 38