Add a test case for making sure gdb can get a stack trace with our debug
authorReid Spencer <rspencer@reidspencer.com>
Tue, 7 Nov 2006 07:31:37 +0000 (07:31 +0000)
committerReid Spencer <rspencer@reidspencer.com>
Tue, 7 Nov 2006 07:31:37 +0000 (07:31 +0000)
information.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31495 91177308-0d34-0410-b5e6-96231b3b80d8

test/DebugInfo/2006-11-06-StackTrace.cpp [new file with mode: 0644]
test/DebugInfo/dg.exp [new file with mode: 0644]

diff --git a/test/DebugInfo/2006-11-06-StackTrace.cpp b/test/DebugInfo/2006-11-06-StackTrace.cpp
new file mode 100644 (file)
index 0000000..fcc8c20
--- /dev/null
@@ -0,0 +1,29 @@
+// This is a regression test on debug info to make sure that we can get a
+// meaningful stack trace from a C++ program.
+// RUN: %llvmgcc -S -O0 -g %s -o Output/%s.ll
+// RUN: llvm-as < Output/%s.ll | llc -o Output/%s.s
+// RUN: gcc -g Output/%s.s -o Output/%s.exe
+// RUN: ( echo "break DeepStack::deepest"; echo "run 17" ; echo "where" ) | gdb Output/%s.exe | grep '#0  DeepStack::deepest (this=.*,x=33)'
+
+#include <stdlib.h>
+
+class DeepStack {
+  int seedVal;
+public:
+  DeepStack(int seed) : seedVal(seed) {}
+
+  int shallowest( int x ) { return shallower(x + 1); }
+  int shallower ( int x ) { return shallow(x + 2); }
+  int shallow   ( int x ) { return deep(x + 3); }
+  int deep      ( int x ) { return deeper(x + 4); }
+  int deeper    ( int x ) { return deepest(x + 6); }
+  int deepest   ( int x ) { return x + 7; }
+
+  int runit() { return shallowest(seedVal); }
+};
+
+int main ( int argc, char** argv) {
+
+  DeepStack DS9( (argc > 1 ? atoi(argv[1]) : 0) );
+  return DS9.runit();
+}
diff --git a/test/DebugInfo/dg.exp b/test/DebugInfo/dg.exp
new file mode 100644 (file)
index 0000000..142de8a
--- /dev/null
@@ -0,0 +1,3 @@
+load_lib llvm-dg.exp
+
+llvm-runtest [lsort [glob -nocomplain $srcdir/$subdir/*.{ll,llx,c,cpp,tr}]] $objdir $srcdir $subdir $target_triplet $llvmgcc $llvmgxx $prcontext $llvmgcc_version