mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-08 18:26:06 +00:00

It turns out that self.dbg.GetSelectedPlatform().GetTriple() is not a good way to get the triple of the process, as it returns the incorrect triple in case of a 32-bit process running on a 64-bit platform. Instead, go the long way round and ask the stub for the process triple. This fixes the test for i386. llvm-svn: 280922
44 lines
1.5 KiB
Python
44 lines
1.5 KiB
Python
from __future__ import print_function
|
|
|
|
|
|
import gdbremote_testcase
|
|
import lldbgdbserverutils
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
class TestGdbRemoteModuleInfo(gdbremote_testcase.GdbRemoteTestCaseBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
def module_info(self):
|
|
procs = self.prep_debug_monitor_and_inferior()
|
|
self.add_process_info_collection_packets()
|
|
context = self.expect_gdbremote_sequence()
|
|
info = self.parse_process_info_response(context)
|
|
|
|
self.test_sequence.add_log_lines([
|
|
'read packet: $jModulesInfo:[{"file":"%s","triple":"%s"}]]#00' % (
|
|
lldbutil.append_to_process_working_directory("a.out"),
|
|
info["triple"].decode('hex')),
|
|
{"direction": "send",
|
|
"regex": r'^\$\[{(.*)}\]\]#[0-9A-Fa-f]{2}',
|
|
"capture": {1: "spec"}},
|
|
], True)
|
|
|
|
context = self.expect_gdbremote_sequence()
|
|
spec = context.get("spec")
|
|
self.assertRegexpMatches(spec, '"file_path":".*"')
|
|
self.assertRegexpMatches(spec, '"file_offset":\d+')
|
|
self.assertRegexpMatches(spec, '"file_size":\d+')
|
|
self.assertRegexpMatches(spec, '"triple":"\w*-\w*-.*"')
|
|
self.assertRegexpMatches(spec, '"uuid":"[A-Fa-f0-9]+"')
|
|
|
|
@llgs_test
|
|
def test_module_info(self):
|
|
self.init_llgs_test()
|
|
self.build()
|
|
self.set_inferior_startup_launch()
|
|
self.module_info()
|