[Lldb-commits] [lldb] r118590 - in /lldb/trunk/test/expression_command: ./ radar_8638051/ radar_8638051/Makefile radar_8638051/Test8638051.py radar_8638051/main.c

Johnny Chen johnny.chen at apple.com
Tue Nov 9 09:51:11 PST 2010


Author: johnny
Date: Tue Nov  9 11:51:11 2010
New Revision: 118590

URL: http://llvm.org/viewvc/llvm-project?rev=118590&view=rev
Log:
Add a test for expression parser crash which has been fixed.

Added:
    lldb/trunk/test/expression_command/
    lldb/trunk/test/expression_command/radar_8638051/
    lldb/trunk/test/expression_command/radar_8638051/Makefile
    lldb/trunk/test/expression_command/radar_8638051/Test8638051.py
    lldb/trunk/test/expression_command/radar_8638051/main.c

Added: lldb/trunk/test/expression_command/radar_8638051/Makefile
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/expression_command/radar_8638051/Makefile?rev=118590&view=auto
==============================================================================
--- lldb/trunk/test/expression_command/radar_8638051/Makefile (added)
+++ lldb/trunk/test/expression_command/radar_8638051/Makefile Tue Nov  9 11:51:11 2010
@@ -0,0 +1,5 @@
+LEVEL = ../../make
+
+C_SOURCES := main.c
+
+include $(LEVEL)/Makefile.rules

Added: lldb/trunk/test/expression_command/radar_8638051/Test8638051.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/expression_command/radar_8638051/Test8638051.py?rev=118590&view=auto
==============================================================================
--- lldb/trunk/test/expression_command/radar_8638051/Test8638051.py (added)
+++ lldb/trunk/test/expression_command/radar_8638051/Test8638051.py Tue Nov  9 11:51:11 2010
@@ -0,0 +1,43 @@
+"""
+Test the robustness of lldb expression parser.
+"""
+
+import os, time
+import unittest2
+import lldb
+from lldbtest import *
+
+class Radar8638051TestCase(TestBase):
+
+    mydir = os.path.join("expression_command", "radar_8638051")
+
+    def test_expr_commands(self):
+        """The following expression commands should not crash."""
+        self.buildDefault()
+
+        self.runCmd("file a.out", CURRENT_EXECUTABLE_SET)
+
+        self.runCmd("breakpoint set -n c")
+
+        self.runCmd("run", RUN_SUCCEEDED)
+
+        self.expect("expression val",
+            startstr = "(int) $0 = 1")
+        # (int) $0 = 1
+
+        self.expect("expression *(&val)",
+            startstr = "(int) $1 = 1")
+        # (int) $1 = 1
+
+        # rdar://problem/8638051
+        # lldb expression command: Could this crash be avoided
+        self.expect("expression &val",
+            startstr = "(int *) $2 = ")
+        # (int *) $2 = 0x....
+
+
+if __name__ == '__main__':
+    import atexit
+    lldb.SBDebugger.Initialize()
+    atexit.register(lambda: lldb.SBDebugger.Terminate())
+    unittest2.main()

Added: lldb/trunk/test/expression_command/radar_8638051/main.c
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/expression_command/radar_8638051/main.c?rev=118590&view=auto
==============================================================================
--- lldb/trunk/test/expression_command/radar_8638051/main.c (added)
+++ lldb/trunk/test/expression_command/radar_8638051/main.c Tue Nov  9 11:51:11 2010
@@ -0,0 +1,54 @@
+//===-- main.c --------------------------------------------------*- C++ -*-===//
+//
+//                     The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+#include <stdio.h>
+
+// This simple program is to demonstrate the capability of the lldb command
+// "breakpoint command add" to add a set of commands to a breakpoint to be
+// executed when the breakpoint is hit.
+//
+// In particular, we want to break within c(), but only if the immediate caller
+// is a().
+
+int a(int);
+int b(int);
+int c(int);
+
+int a(int val)
+{
+    if (val <= 1)
+        return b(val);
+    else if (val >= 3)
+        return c(val); // Find the line number where c's parent frame is a here.
+
+    return val;
+}
+
+int b(int val)
+{
+    return c(val);
+}
+
+int c(int val)
+{
+    return val + 3;
+}
+
+int main (int argc, char const *argv[])
+{
+    int A1 = a(1);  // a(1) -> b(1) -> c(1)
+    printf("a(1) returns %d\n", A1);
+    
+    int B2 = b(2);  // b(2) -> c(2)
+    printf("b(2) returns %d\n", B2);
+    
+    int A3 = a(3);  // a(3) -> c(3)
+    printf("a(3) returns %d\n", A3);
+    
+    return 0;
+}





More information about the lldb-commits mailing list