Add Python API tests for file and class static variables, too.

llvm-svn: 119758
This commit is contained in:
Johnny Chen 2010-11-18 23:33:43 +00:00
parent 99d0faf27e
commit 835a88cb15
1 changed files with 65 additions and 2 deletions

View File

@ -18,10 +18,21 @@ class StaticVariableTestCase(TestBase):
self.static_variable_commands()
def test_with_dwarf_and_run_command(self):
"""Test that anonymous and named namespace variables display correctly."""
"""Test that file and class static variables display correctly."""
self.buildDwarf()
self.static_variable_commands()
@unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
def test_with_dsym_and_python_api(self):
"""Test Python APIs on file and class static variables."""
self.buildDsym()
self.static_variable_python()
def test_with_dwarf_and_python_api(self):
"""Test Python APIs on file and class static variables."""
self.buildDwarf()
self.static_variable_python()
def setUp(self):
# Call super's setUp().
TestBase.setUp(self)
@ -29,7 +40,7 @@ class StaticVariableTestCase(TestBase):
self.line = line_number('main.cpp', '// Set break point at this line.')
def static_variable_commands(self):
"""Test that anonymous and named namespace variables display correctly."""
"""Test that that file and class static variables display correctly."""
self.runCmd("file a.out", CURRENT_EXECUTABLE_SET)
self.expect("breakpoint set -f main.cpp -l %d" % self.line,
@ -56,6 +67,58 @@ class StaticVariableTestCase(TestBase):
self.expect("frame variable A::g_points[1].x", VARIABLES_DISPLAYED_CORRECTLY,
startstr = "(int) A::g_points[1].x = 11")
def static_variable_python(self):
"""Test Python APIs on file and class static variables."""
exe = os.path.join(os.getcwd(), "a.out")
target = self.dbg.CreateTarget(exe)
self.assertTrue(target.IsValid(), VALID_TARGET)
breakpoint = target.BreakpointCreateByLocation("main.cpp", self.line)
self.assertTrue(breakpoint.IsValid(), VALID_BREAKPOINT)
# Now launch the process, and do not stop at entry point.
self.process = target.LaunchProcess([''], [''], os.ctermid(), 0, False)
self.process = target.GetProcess()
self.assertTrue(self.process.IsValid(), PROCESS_IS_VALID)
# The stop reason of the thread should be breakpoint.
thread = self.process.GetThreadAtIndex(0)
if thread.GetStopReason() != lldb.eStopReasonBreakpoint:
from lldbutil import StopReasonString
self.fail(STOPPED_DUE_TO_BREAKPOINT_WITH_STOP_REASON_AS %
StopReasonString(thread.GetStopReason()))
# Get the SBValue of 'A::g_points' and 'g_points'.
frame = thread.GetFrameAtIndex(0)
# arguments => False
# locals => False
# statics => True
# in_scope_only => False
valList = frame.GetVariables(False, False, True, False)
from lldbutil import lldb_iter
for val in lldb_iter(valList, 'GetSize', 'GetValueAtIndex'):
self.DebugSBValue(frame, val)
self.assertTrue(val.GetValueType() == lldb.eValueTypeVariableGlobal)
name = val.GetName()
self.assertTrue(name in ['g_points', 'A::g_points'])
if name == 'g_points':
self.assertTrue(val.GetNumChildren() == 2)
elif name == 'A::g_points' and self.getCompiler() in ['clang', 'llvm-gcc']:
self.assertTrue(val.GetNumChildren() == 2)
child1 = val.GetChildAtIndex(1)
self.DebugSBValue(frame, child1)
child1_x = child1.GetChildAtIndex(0)
self.DebugSBValue(frame, child1_x)
self.assertTrue(child1_x.GetTypeName() == 'int' and
child1_x.GetValue(frame) == '11')
#variable = frame.LookupVarInScope("A::g_points", "global")
#print "variable:", repr(variable)
if __name__ == '__main__':
import atexit