[Lldb-commits] [PATCH] Create new test for expression evaluation where char type matters

Tamas Berghammer tberghammer at google.com
Tue Mar 31 02:51:53 PDT 2015


REPOSITORY
  rL LLVM

http://reviews.llvm.org/D8657

Files:
  lldb/trunk/test/expression_command/char/Makefile
  lldb/trunk/test/expression_command/char/TestExprsChar.py
  lldb/trunk/test/expression_command/char/main.cpp

Index: lldb/trunk/test/expression_command/char/main.cpp
===================================================================
--- lldb/trunk/test/expression_command/char/main.cpp
+++ lldb/trunk/test/expression_command/char/main.cpp
@@ -0,0 +1,10 @@
+int foo(char c) { return 1; }
+int foo(signed char c) { return 2; }
+int foo(unsigned char c) { return 3; }
+
+int main() {
+  char c = 0;
+  signed char sc = 0;
+  unsigned char uc = 0;
+  return 0; // Break here
+}
Index: lldb/trunk/test/expression_command/char/TestExprsChar.py
===================================================================
--- lldb/trunk/test/expression_command/char/TestExprsChar.py
+++ lldb/trunk/test/expression_command/char/TestExprsChar.py
@@ -0,0 +1,68 @@
+import unittest2
+import lldb
+import lldbutil
+from lldbtest import *
+
+class ExprCharTestCase(TestBase):
+
+    mydir = TestBase.compute_mydir(__file__)
+
+    def setUp(self):
+        # Call super's setUp().
+        TestBase.setUp(self)
+
+        self.main_source = "main.cpp"
+        self.main_source_spec = lldb.SBFileSpec (self.main_source)
+        self.exe = os.path.join(os.getcwd(), "a.out")
+
+    def do_test(self, dictionary=None):
+        """These basic expression commands should work as expected."""
+        self.buildDefault(dictionary = dictionary)
+
+        target = self.dbg.CreateTarget(self.exe)
+        self.assertTrue(target)
+
+        breakpoint = target.BreakpointCreateBySourceRegex('// Break here', self.main_source_spec)
+        self.assertTrue(breakpoint)
+
+        # Launch the process, and do not stop at the entry point.
+        process = target.LaunchSimple(None, None, self.get_process_working_directory())
+        self.assertTrue(process)
+
+        threads = lldbutil.get_threads_stopped_at_breakpoint(process, breakpoint)
+        self.assertEqual(len(threads), 1)
+
+        frame = threads[0].GetFrameAtIndex(0)
+
+        value = frame.EvaluateExpression("foo(c)")
+        self.assertTrue(value.IsValid())
+        self.assertTrue(value.GetError().Success())
+        self.assertEqual(value.GetValueAsSigned(0), 1)
+
+        value = frame.EvaluateExpression("foo(sc)")
+        self.assertTrue(value.IsValid())
+        self.assertTrue(value.GetError().Success())
+        self.assertEqual(value.GetValueAsSigned(0), 2)
+
+        value = frame.EvaluateExpression("foo(uc)")
+        self.assertTrue(value.IsValid())
+        self.assertTrue(value.GetError().Success())
+        self.assertEqual(value.GetValueAsSigned(0), 3)
+
+    def test_default_char(self):
+        self.do_test()
+
+    
+    def test_signed_char(self):
+        self.do_test(dictionary={'CFLAGS_EXTRAS': '-fsigned-char'})
+
+    @expectedFailurei386("llvm.org/pr23069")
+    @expectedFailurex86_64("llvm.org/pr23069")
+    def test_unsigned_char(self):
+        self.do_test(dictionary={'CFLAGS_EXTRAS': '-funsigned-char'})
+
+if __name__ == '__main__':
+    import atexit
+    lldb.SBDebugger.Initialize()
+    atexit.register(lambda: lldb.SBDebugger.Terminate())
+    unittest2.main()
Index: lldb/trunk/test/expression_command/char/Makefile
===================================================================
--- lldb/trunk/test/expression_command/char/Makefile
+++ lldb/trunk/test/expression_command/char/Makefile
@@ -0,0 +1,5 @@
+LEVEL = ../../make
+
+CXX_SOURCES := main.cpp
+
+include $(LEVEL)/Makefile.rules

EMAIL PREFERENCES
  http://reviews.llvm.org/settings/panel/emailpreferences/
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D8657.22933.patch
Type: text/x-patch
Size: 3383 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20150331/e29e227f/attachment.bin>


More information about the lldb-commits mailing list