Add Python API tests for file and class static variables, too.
llvm-svn: 119758
This commit is contained in:
parent
99d0faf27e
commit
835a88cb15
|
@ -18,10 +18,21 @@ class StaticVariableTestCase(TestBase):
|
||||||
self.static_variable_commands()
|
self.static_variable_commands()
|
||||||
|
|
||||||
def test_with_dwarf_and_run_command(self):
|
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.buildDwarf()
|
||||||
self.static_variable_commands()
|
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):
|
def setUp(self):
|
||||||
# Call super's setUp().
|
# Call super's setUp().
|
||||||
TestBase.setUp(self)
|
TestBase.setUp(self)
|
||||||
|
@ -29,7 +40,7 @@ class StaticVariableTestCase(TestBase):
|
||||||
self.line = line_number('main.cpp', '// Set break point at this line.')
|
self.line = line_number('main.cpp', '// Set break point at this line.')
|
||||||
|
|
||||||
def static_variable_commands(self):
|
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.runCmd("file a.out", CURRENT_EXECUTABLE_SET)
|
||||||
|
|
||||||
self.expect("breakpoint set -f main.cpp -l %d" % self.line,
|
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,
|
self.expect("frame variable A::g_points[1].x", VARIABLES_DISPLAYED_CORRECTLY,
|
||||||
startstr = "(int) A::g_points[1].x = 11")
|
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__':
|
if __name__ == '__main__':
|
||||||
import atexit
|
import atexit
|
||||||
|
|
Loading…
Reference in New Issue