"""
Test the solution to issue 11581.
valobj.AddressOf() returns None when an address is
expected in a SyntheticChildrenProvider
"""
import lldb
from lldbsuite.test.decorators import *
from lldbsuite.test.lldbtest import *
from lldbsuite.test import lldbutil
class Issue11581TestCase(TestBase):
@skipIfWindows # This test is now flaky on windows, see llvm.org/pr24778
def test_11581_commands(self):
# This is the function to remove the custom commands in order to have a
# clean slate for the next test case.
def cleanup():
self.runCmd("type synthetic clear", check=False)
# Execute the cleanup function during test case tear down.
self.addTearDownHook(cleanup)
"""valobj.AddressOf() should return correct values."""
self.build()
(target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(
self, "Set breakpoint here.", lldb.SBFileSpec("main.cpp", False)
)
self.runCmd("command script import --allow-reload s11588.py")
self.runCmd(
"type synthetic add --python-class s11588.Issue11581SyntheticProvider StgClosure"
)
self.expect(
"expr --show-types -- *((StgClosure*)(r14-1))",
substrs=[
"(StgClosure) $",
"(StgClosure *) &$",
"0x",
"addr = ",
"load_address = ",
],
)
# register r14 is an x86_64 extension let's skip this part of the test
# if we are on a different architecture
if self.getArchitecture() == "x86_64":
target = self.dbg.GetSelectedTarget()
process = target.GetProcess()
frame = process.GetSelectedThread().GetSelectedFrame()
pointer = frame.FindVariable("r14")
addr = pointer.GetValueAsUnsigned(0)
self.assertNotEqual(addr, 0, "could not read pointer to StgClosure")
addr = addr - 1
self.runCmd("register write r14 %d" % addr)
self.expect(
"register read r14", substrs=["0x", hex(addr)[2:].rstrip("L")]
) # Remove trailing 'L' if it exists
self.expect(
"expr --show-types -- *(StgClosure*)$r14",
substrs=[
"(StgClosure) $",
"(StgClosure *) &$",
"0x",
hex(addr)[2:].rstrip("L"),
"addr = ",
str(addr),
"load_address = ",
str(addr),
],
)