2011-07-16 06:28:10 +08:00
|
|
|
"""
|
|
|
|
Test some SBValue APIs.
|
|
|
|
"""
|
|
|
|
|
2015-10-24 01:04:29 +08:00
|
|
|
from __future__ import print_function
|
|
|
|
|
2016-02-05 07:04:17 +08:00
|
|
|
import os
|
2011-07-16 06:28:10 +08:00
|
|
|
import re
|
2016-02-05 07:04:17 +08:00
|
|
|
import time
|
|
|
|
|
2015-11-03 10:06:18 +08:00
|
|
|
import lldb
|
2016-02-05 07:04:17 +08:00
|
|
|
from lldbsuite.test.decorators import *
|
2015-11-03 10:06:18 +08:00
|
|
|
from lldbsuite.test.lldbtest import *
|
2016-02-05 07:04:17 +08:00
|
|
|
from lldbsuite.test import lldbutil
|
2011-07-16 06:28:10 +08:00
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2011-07-16 06:28:10 +08:00
|
|
|
class ValueAPITestCase(TestBase):
|
|
|
|
|
2013-12-11 07:19:29 +08:00
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
2011-07-16 06:28:10 +08:00
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
# Call super's setUp().
|
|
|
|
TestBase.setUp(self)
|
|
|
|
# We'll use the test method name as the exe_name.
|
|
|
|
self.exe_name = self.testMethodName
|
|
|
|
# Find the line number to of function 'c'.
|
|
|
|
self.line = line_number('main.c', '// Break at this line')
|
|
|
|
|
2016-02-09 03:34:59 +08:00
|
|
|
@expectedFailureAll(oslist=["windows"], bugnumber="llvm.org/pr24772")
|
2015-10-26 17:28:32 +08:00
|
|
|
@add_test_categories(['pyapi'])
|
2015-09-30 18:12:40 +08:00
|
|
|
def test(self):
|
2011-07-16 06:28:10 +08:00
|
|
|
"""Exercise some SBValue APIs."""
|
2015-09-30 18:12:40 +08:00
|
|
|
d = {'EXE': self.exe_name}
|
|
|
|
self.build(dictionary=d)
|
|
|
|
self.setTearDownCleanup(dictionary=d)
|
2018-01-31 02:29:16 +08:00
|
|
|
exe = self.getBuildArtifact(self.exe_name)
|
2011-07-16 06:28:10 +08:00
|
|
|
|
|
|
|
# Create a target by the debugger.
|
|
|
|
target = self.dbg.CreateTarget(exe)
|
|
|
|
self.assertTrue(target, VALID_TARGET)
|
|
|
|
|
|
|
|
# Create the breakpoint inside function 'main'.
|
|
|
|
breakpoint = target.BreakpointCreateByLocation('main.c', self.line)
|
|
|
|
self.assertTrue(breakpoint, VALID_BREAKPOINT)
|
|
|
|
|
|
|
|
# Now launch the process, and do not stop at entry point.
|
2016-09-07 04:57:50 +08:00
|
|
|
process = target.LaunchSimple(
|
|
|
|
None, None, self.get_process_working_directory())
|
2011-07-16 06:28:10 +08:00
|
|
|
self.assertTrue(process, PROCESS_IS_VALID)
|
|
|
|
|
|
|
|
# Get Frame #0.
|
|
|
|
self.assertTrue(process.GetState() == lldb.eStateStopped)
|
2016-09-07 04:57:50 +08:00
|
|
|
thread = lldbutil.get_stopped_thread(
|
|
|
|
process, lldb.eStopReasonBreakpoint)
|
|
|
|
self.assertTrue(
|
|
|
|
thread.IsValid(),
|
|
|
|
"There should be a thread stopped due to breakpoint condition")
|
2011-07-16 06:28:10 +08:00
|
|
|
frame0 = thread.GetFrameAtIndex(0)
|
|
|
|
|
2011-07-22 07:02:00 +08:00
|
|
|
# Get global variable 'days_of_week'.
|
|
|
|
list = target.FindGlobalVariables('days_of_week', 1)
|
|
|
|
days_of_week = list.GetValueAtIndex(0)
|
|
|
|
self.assertTrue(days_of_week, VALID_VARIABLE)
|
2018-05-04 09:31:47 +08:00
|
|
|
self.assertEqual(days_of_week.GetNumChildren(), 7, VALID_VARIABLE)
|
2011-07-22 07:02:00 +08:00
|
|
|
self.DebugSBValue(days_of_week)
|
|
|
|
|
2018-05-04 09:31:47 +08:00
|
|
|
# Use this to test the "child" and "children" accessors:
|
|
|
|
children = days_of_week.children
|
|
|
|
self.assertEqual(len(children), 7, VALID_VARIABLE)
|
|
|
|
for i in range(0, len(children)):
|
|
|
|
day = days_of_week.child[i]
|
|
|
|
list_day = children[i]
|
|
|
|
self.assertNotEqual(day, None)
|
|
|
|
self.assertNotEqual(list_day, None)
|
|
|
|
self.assertEqual(day.GetSummary(), list_day.GetSummary(), VALID_VARIABLE)
|
|
|
|
|
|
|
|
# Spot check the actual value:
|
|
|
|
first_day = days_of_week.child[1]
|
|
|
|
self.assertEqual(first_day.GetSummary(), '"Monday"', VALID_VARIABLE)
|
|
|
|
|
2011-07-23 06:01:35 +08:00
|
|
|
# Get global variable 'weekdays'.
|
|
|
|
list = target.FindGlobalVariables('weekdays', 1)
|
|
|
|
weekdays = list.GetValueAtIndex(0)
|
|
|
|
self.assertTrue(weekdays, VALID_VARIABLE)
|
|
|
|
self.assertTrue(weekdays.GetNumChildren() == 5, VALID_VARIABLE)
|
|
|
|
self.DebugSBValue(weekdays)
|
|
|
|
|
|
|
|
# Get global variable 'g_table'.
|
|
|
|
list = target.FindGlobalVariables('g_table', 1)
|
|
|
|
g_table = list.GetValueAtIndex(0)
|
|
|
|
self.assertTrue(g_table, VALID_VARIABLE)
|
|
|
|
self.assertTrue(g_table.GetNumChildren() == 2, VALID_VARIABLE)
|
|
|
|
self.DebugSBValue(g_table)
|
|
|
|
|
2011-07-22 08:47:58 +08:00
|
|
|
fmt = lldbutil.BasicFormatter()
|
2011-07-23 06:01:35 +08:00
|
|
|
cvf = lldbutil.ChildVisitingFormatter(indent_child=2)
|
|
|
|
rdf = lldbutil.RecursiveDecentFormatter(indent_child=2)
|
2011-07-22 08:47:58 +08:00
|
|
|
if self.TraceOn():
|
2015-10-24 01:04:29 +08:00
|
|
|
print(fmt.format(days_of_week))
|
|
|
|
print(cvf.format(days_of_week))
|
|
|
|
print(cvf.format(weekdays))
|
|
|
|
print(rdf.format(g_table))
|
2011-07-22 08:47:58 +08:00
|
|
|
|
2011-11-16 05:13:13 +08:00
|
|
|
# Get variable 'my_int_ptr'.
|
|
|
|
value = frame0.FindVariable('my_int_ptr')
|
|
|
|
self.assertTrue(value, VALID_VARIABLE)
|
|
|
|
self.DebugSBValue(value)
|
|
|
|
|
|
|
|
# Get what 'my_int_ptr' points to.
|
|
|
|
pointed = value.GetChildAtIndex(0)
|
|
|
|
self.assertTrue(pointed, VALID_VARIABLE)
|
|
|
|
self.DebugSBValue(pointed)
|
|
|
|
|
2011-11-16 07:30:39 +08:00
|
|
|
# While we are at it, verify that 'my_int_ptr' points to 'g_my_int'.
|
2016-09-07 04:57:50 +08:00
|
|
|
symbol = target.ResolveLoadAddress(
|
|
|
|
int(pointed.GetLocation(), 0)).GetSymbol()
|
2011-11-16 07:30:39 +08:00
|
|
|
self.assertTrue(symbol)
|
|
|
|
self.expect(symbol.GetName(), exe=False,
|
2016-09-07 04:57:50 +08:00
|
|
|
startstr='g_my_int')
|
2011-11-16 07:30:39 +08:00
|
|
|
|
2011-07-16 06:28:10 +08:00
|
|
|
# Get variable 'str_ptr'.
|
|
|
|
value = frame0.FindVariable('str_ptr')
|
|
|
|
self.assertTrue(value, VALID_VARIABLE)
|
|
|
|
self.DebugSBValue(value)
|
|
|
|
|
2011-07-22 03:31:59 +08:00
|
|
|
# SBValue::TypeIsPointerType() should return true.
|
|
|
|
self.assertTrue(value.TypeIsPointerType())
|
|
|
|
|
|
|
|
# Verify the SBValue::GetByteSize() API is working correctly.
|
|
|
|
arch = self.getArchitecture()
|
|
|
|
if arch == 'i386':
|
|
|
|
self.assertTrue(value.GetByteSize() == 4)
|
|
|
|
elif arch == 'x86_64':
|
|
|
|
self.assertTrue(value.GetByteSize() == 8)
|
|
|
|
|
2011-07-16 06:28:10 +08:00
|
|
|
# Get child at index 5 => 'Friday'.
|
|
|
|
child = value.GetChildAtIndex(5, lldb.eNoDynamicValues, True)
|
|
|
|
self.assertTrue(child, VALID_VARIABLE)
|
|
|
|
self.DebugSBValue(child)
|
|
|
|
|
|
|
|
self.expect(child.GetSummary(), exe=False,
|
2016-09-07 04:57:50 +08:00
|
|
|
substrs=['Friday'])
|
2011-07-16 06:28:10 +08:00
|
|
|
|
|
|
|
# Now try to get at the same variable using GetValueForExpressionPath().
|
|
|
|
# These two SBValue objects should have the same value.
|
|
|
|
val2 = value.GetValueForExpressionPath('[5]')
|
|
|
|
self.assertTrue(val2, VALID_VARIABLE)
|
|
|
|
self.DebugSBValue(val2)
|
|
|
|
self.assertTrue(child.GetValue() == val2.GetValue() and
|
|
|
|
child.GetSummary() == val2.GetSummary())
|
2015-07-16 09:47:12 +08:00
|
|
|
|
|
|
|
val_i = target.EvaluateExpression('i')
|
|
|
|
val_s = target.EvaluateExpression('s')
|
|
|
|
val_a = target.EvaluateExpression('a')
|
2016-09-07 04:57:50 +08:00
|
|
|
self.assertTrue(
|
|
|
|
val_s.GetChildMemberWithName('a').AddressOf(),
|
|
|
|
VALID_VARIABLE)
|
|
|
|
self.assertTrue(
|
|
|
|
val_a.Cast(
|
|
|
|
val_i.GetType()).AddressOf(),
|
|
|
|
VALID_VARIABLE)
|
|
|
|
|
|
|
|
self.assertTrue(int(lldb.value(frame0.FindVariable('uinthex')))
|
|
|
|
== 3768803088, 'uinthex == 3768803088')
|
|
|
|
self.assertTrue(int(lldb.value(frame0.FindVariable('sinthex')))
|
|
|
|
== -526164208, 'sinthex == -526164208')
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
frame0.FindVariable('uinthex').GetValueAsUnsigned() == 3768803088,
|
|
|
|
'unsigned uinthex == 3768803088')
|
|
|
|
self.assertTrue(
|
|
|
|
frame0.FindVariable('sinthex').GetValueAsUnsigned() == 3768803088,
|
|
|
|
'unsigned sinthex == 3768803088')
|
|
|
|
|
|
|
|
self.assertTrue(
|
|
|
|
frame0.FindVariable('uinthex').GetValueAsSigned() == -
|
|
|
|
526164208,
|
|
|
|
'signed uinthex == -526164208')
|
|
|
|
self.assertTrue(
|
|
|
|
frame0.FindVariable('sinthex').GetValueAsSigned() == -
|
|
|
|
526164208,
|
|
|
|
'signed sinthex == -526164208')
|