185 lines
6.7 KiB
Python
185 lines
6.7 KiB
Python
import lldb
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test.decorators import *
|
|
import json
|
|
import os
|
|
|
|
|
|
class TestTargetSourceMap(TestBase):
|
|
@no_debug_info_test
|
|
def test_source_map_via_setting_api(self):
|
|
"""
|
|
Test that ensures SBDebugger::GetSetting("target.source-map") API
|
|
can correctly fetch source mapping entries.
|
|
"""
|
|
# Set the target soure map to map "./" to the current test directory
|
|
src_dir = self.getSourceDir()
|
|
|
|
source_map_setting_path = "target.source-map"
|
|
initial_source_map = self.dbg.GetSetting(source_map_setting_path)
|
|
self.assertEquals(
|
|
initial_source_map.GetSize(), 0, "Initial source map should be empty"
|
|
)
|
|
|
|
src_dir = self.getSourceDir()
|
|
self.runCmd('settings set %s . "%s"' % (source_map_setting_path, src_dir))
|
|
|
|
source_map = self.dbg.GetSetting(source_map_setting_path)
|
|
self.assertEquals(
|
|
source_map.GetSize(), 1, "source map should be have one appended entry"
|
|
)
|
|
|
|
stream = lldb.SBStream()
|
|
source_map.GetAsJSON(stream)
|
|
serialized_source_map = json.loads(stream.GetData())
|
|
|
|
self.assertEquals(
|
|
len(serialized_source_map[0]), 2, "source map entry should have two parts"
|
|
)
|
|
self.assertEquals(
|
|
serialized_source_map[0][0],
|
|
".",
|
|
"source map entry's first part does not match",
|
|
)
|
|
self.assertEquals(
|
|
serialized_source_map[0][1],
|
|
src_dir,
|
|
"source map entry's second part does not match",
|
|
)
|
|
|
|
@no_debug_info_test
|
|
def test_source_map(self):
|
|
"""Test target.source-map' functionality."""
|
|
|
|
def assertBreakpointWithSourceMap(src_path):
|
|
# Set a breakpoint after we remap source and verify that it succeeds
|
|
bp = target.BreakpointCreateByLocation(src_path, 2)
|
|
self.assertEquals(
|
|
bp.GetNumLocations(), 1, "make sure breakpoint was resolved with map"
|
|
)
|
|
|
|
# Now make sure that we can actually FIND the source file using this
|
|
# remapping:
|
|
retval = lldb.SBCommandReturnObject()
|
|
self.dbg.GetCommandInterpreter().HandleCommand(
|
|
"source list -f main.c -l 2", retval
|
|
)
|
|
self.assertTrue(retval.Succeeded(), "source list didn't succeed.")
|
|
self.assertNotEqual(
|
|
retval.GetOutput(), None, "We got no ouput from source list"
|
|
)
|
|
self.assertIn(
|
|
"return", retval.GetOutput(), "We didn't find the source file..."
|
|
)
|
|
|
|
# Set the target soure map to map "./" to the current test directory
|
|
src_dir = self.getSourceDir()
|
|
src_path = os.path.join(src_dir, "main.c")
|
|
yaml_path = os.path.join(src_dir, "a.yaml")
|
|
yaml_base, ext = os.path.splitext(yaml_path)
|
|
obj_path = self.getBuildArtifact("main.o")
|
|
self.yaml2obj(yaml_path, obj_path)
|
|
|
|
# Create a target with the object file we just created from YAML
|
|
target = self.dbg.CreateTarget(obj_path)
|
|
|
|
# Set a breakpoint before we remap source and verify that it fails
|
|
bp = target.BreakpointCreateByLocation(src_path, 2)
|
|
self.assertEquals(
|
|
bp.GetNumLocations(),
|
|
0,
|
|
"make sure no breakpoints were resolved without map",
|
|
)
|
|
|
|
valid_path = os.path.dirname(src_dir)
|
|
valid_path2 = os.path.dirname(valid_path)
|
|
invalid_path = src_dir + "invalid_path"
|
|
invalid_path2 = src_dir + "invalid_path2"
|
|
|
|
# We make sure the error message contains all the invalid paths
|
|
self.expect(
|
|
'settings set target.source-map . "%s" . "%s" . "%s" . "%s'
|
|
% (invalid_path, src_dir, invalid_path2, valid_path),
|
|
substrs=[
|
|
'error: the replacement path doesn\'t exist: "%s"' % (invalid_path),
|
|
'the replacement path doesn\'t exist: "%s"' % (invalid_path2),
|
|
],
|
|
error=True,
|
|
)
|
|
self.expect(
|
|
"settings show target.source-map",
|
|
substrs=[
|
|
'[0] "." -> "%s"' % (src_dir),
|
|
'[1] "." -> "%s"' % (valid_path),
|
|
],
|
|
)
|
|
assertBreakpointWithSourceMap(src_path)
|
|
|
|
# Attempts to replace an index to an invalid mapping should have no effect.
|
|
# Modifications to valid mappings should work.
|
|
self.expect(
|
|
'settings replace target.source-map 0 . "%s" . "%s"'
|
|
% (invalid_path, valid_path2),
|
|
substrs=[
|
|
'error: the replacement path doesn\'t exist: "%s"' % (invalid_path),
|
|
],
|
|
error=True,
|
|
)
|
|
self.expect(
|
|
"settings show target.source-map",
|
|
substrs=[
|
|
'[0] "." -> "%s"' % (src_dir),
|
|
'[1] "." -> "%s"' % (valid_path2),
|
|
],
|
|
)
|
|
assertBreakpointWithSourceMap(src_path)
|
|
|
|
# Let's clear and add the mapping back with insert-after
|
|
self.runCmd("settings remove target.source-map 0")
|
|
self.expect(
|
|
"settings show target.source-map",
|
|
substrs=['[0] "." -> "%s"' % (valid_path2)],
|
|
)
|
|
|
|
self.expect(
|
|
'settings insert-after target.source-map 0 . "%s" . "%s" . "%s"'
|
|
% (invalid_path, invalid_path2, src_dir),
|
|
substrs=[
|
|
'error: the replacement path doesn\'t exist: "%s"' % (invalid_path),
|
|
'the replacement path doesn\'t exist: "%s"' % (invalid_path2),
|
|
],
|
|
error=True,
|
|
)
|
|
self.expect(
|
|
"settings show target.source-map",
|
|
substrs=[
|
|
'[0] "." -> "%s"' % (valid_path2),
|
|
'[1] "." -> "%s"' % (src_dir),
|
|
],
|
|
)
|
|
|
|
# Let's clear using remove and add the mapping in with append
|
|
self.runCmd("settings remove target.source-map 1")
|
|
self.expect(
|
|
"settings show target.source-map",
|
|
substrs=[
|
|
'[0] "." -> "%s"' % (valid_path2),
|
|
],
|
|
)
|
|
self.runCmd("settings clear target.source-map")
|
|
self.expect(
|
|
'settings append target.source-map . "%s" . "%s" . "%s"'
|
|
% (invalid_path, src_dir, invalid_path2),
|
|
substrs=[
|
|
'error: the replacement path doesn\'t exist: "%s"' % (invalid_path),
|
|
'the replacement path doesn\'t exist: "%s"' % (invalid_path2),
|
|
],
|
|
error=True,
|
|
)
|
|
self.expect(
|
|
"settings show target.source-map",
|
|
substrs=[
|
|
'[0] "." -> "%s"' % (src_dir),
|
|
],
|
|
)
|
|
assertBreakpointWithSourceMap(src_path)
|