# This test checks that we make the executable the first
# element in the image list.
import lldb
from lldbsuite.test.decorators import *
from lldbsuite.test.lldbtest import *
from lldbsuite.test import lldbutil
class TestExecutableIsFirst(TestBase):
NO_DEBUG_INFO_TESTCASE = True
# ELF does not have a hard distinction between shared libraries and
# (position-independent) executables
@skipIf(oslist=no_match(lldbplatformutil.getDarwinOSTriples() + ["windows"]))
def test_executable_is_first_before_run(self):
self.build()
ctx = self.platformContext
lib_name = ctx.shlib_prefix + "bar." + ctx.shlib_extension
exe = self.getBuildArtifact("a.out")
lib = self.getBuildArtifact(lib_name)
target = self.dbg.CreateTarget(None)
module = target.AddModule(lib, None, None)
self.assertTrue(module.IsValid(), "Added the module for the library")
module = target.AddModule(exe, None, None)
self.assertTrue(module.IsValid(), "Added the executable module")
# This is the executable module so it should be the first in the list:
first_module = target.GetModuleAtIndex(0)
print("This is the first test, this one succeeds")
self.assertEqual(module, first_module, "This executable is the first module")
# The executable property is an SBFileSpec to the executable. Make sure
# that is also right:
executable_module = target.executable
self.assertEqual(
first_module.file, executable_module, "Python property is also our module"
)
def test_executable_is_first_during_run(self):
self.build()
(target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(
self,
"break after function call",
lldb.SBFileSpec("main.cpp"),
extra_images=["bar"],
)
first_module = target.GetModuleAtIndex(0)
self.assertTrue(first_module.IsValid(), "We have at least one module")
executable_module = target.executable
self.assertEqual(first_module.file, executable_module, "They are the same")