[Lldb-commits] [lldb] r111937 - /lldb/trunk/test/bitfields/TestBitfields.py

Johnny Chen johnny.chen at apple.com
Tue Aug 24 11:21:23 PDT 2010


Author: johnny
Date: Tue Aug 24 13:21:23 2010
New Revision: 111937

URL: http://llvm.org/viewvc/llvm-project?rev=111937&view=rev
Log:
Added test case TestBitfields.py for rdar://problem/8348251, where
"variable list bits" display bits variable correctly, but not "variable list".

Added:
    lldb/trunk/test/bitfields/TestBitfields.py

Added: lldb/trunk/test/bitfields/TestBitfields.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/bitfields/TestBitfields.py?rev=111937&view=auto
==============================================================================
--- lldb/trunk/test/bitfields/TestBitfields.py (added)
+++ lldb/trunk/test/bitfields/TestBitfields.py Tue Aug 24 13:21:23 2010
@@ -0,0 +1,61 @@
+"""Show bitfields and check that they display correctly."""
+
+import os, time
+import unittest2
+import lldb
+from lldbtest import *
+
+class TestBitfields(TestBase):
+
+    mydir = "bitfields"
+
+    @unittest2.expectedFailure
+    def test_global_variables(self):
+        """Test 'variable list ...' and check for correct display."""
+        exe = os.path.join(os.getcwd(), "a.out")
+        self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
+
+        # Break inside the main.
+        self.expect("breakpoint set -f main.c -l 42", BREAKPOINT_CREATED,
+            startstr = "Breakpoint created: 1: file ='main.c', line = 42, locations = 1")
+
+        self.runCmd("run", RUN_STOPPED)
+
+        # The stop reason of the thread should be breakpoint.
+        self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
+            substrs = ['state is Stopped',
+                       'stop reason = breakpoint'])
+
+        # The breakpoint should have a hit count of 1.
+        self.expect("breakpoint list", BREAKPOINT_HIT_ONCE,
+            substrs = [' resolved, hit count = 1'])
+
+        # This should display correctly.
+        self.expect("variable list bits", VARIABLES_DISPLAYED_CORRECTLY,
+            substrs = ['(uint32_t:1) b1 = 0x00000001,',
+                       '(uint32_t:2) b2 = 0x00000003,',
+                       '(uint32_t:3) b3 = 0x00000007,',
+                       '(uint32_t:4) b4 = 0x0000000f,',
+                       '(uint32_t:5) b5 = 0x0000001f,',
+                       '(uint32_t:6) b6 = 0x0000003f,',
+                       '(uint32_t:7) b7 = 0x0000007f,',
+                       '(uint32_t:4) four = 0x0000000f'])
+
+        # And so should this.
+        # rdar://problem/8348251
+        self.expect("variable list", VARIABLES_DISPLAYED_CORRECTLY,
+            substrs = ['(uint32_t:1) b1 = 0x00000001,',
+                       '(uint32_t:2) b2 = 0x00000003,',
+                       '(uint32_t:3) b3 = 0x00000007,',
+                       '(uint32_t:4) b4 = 0x0000000f,',
+                       '(uint32_t:5) b5 = 0x0000001f,',
+                       '(uint32_t:6) b6 = 0x0000003f,',
+                       '(uint32_t:7) b7 = 0x0000007f,',
+                       '(uint32_t:4) four = 0x0000000f'])
+
+
+if __name__ == '__main__':
+    import atexit
+    lldb.SBDebugger.Initialize()
+    atexit.register(lambda: lldb.SBDebugger.Terminate())
+    unittest2.main()





More information about the lldb-commits mailing list