This infrastructure has proven proven its worth, so give it a more prominent place. My immediate motivation for this is the desire to reuse this infrastructure for qemu platform testing, but I believe this move makes sense independently of that. Moving this code to the packages tree will allow as to add more structure to the gdb client tests -- currently they are all crammed into the same test folder as that was the only way they could access this code. I'm splitting the code into two parts while moving it. The first once contains just the generic gdb protocol wrappers, while the other one contains the unit test glue. The reason for that is that for qemu testing, I need to run the gdb code in a separate process, so I will only be using the first part there. Differential Revision: https://reviews.llvm.org/D113893
68 lines
2.6 KiB
Python
68 lines
2.6 KiB
Python
import lldb
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.gdbclientutils import *
|
|
from lldbsuite.test.lldbgdbclient import GDBRemoteTestBase
|
|
|
|
class TestIOSSimulator(GDBRemoteTestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
"""
|
|
Test that an ios simulator process is recognized as such.
|
|
"""
|
|
|
|
class MyResponder(MockGDBServerResponder):
|
|
def __init__(self, host, process):
|
|
self.host_ostype = host
|
|
self.process_ostype = process
|
|
MockGDBServerResponder.__init__(self)
|
|
|
|
def respond(self, packet):
|
|
if packet == "qProcessInfo":
|
|
return self.qProcessInfo()
|
|
return MockGDBServerResponder.respond(self, packet)
|
|
|
|
def qHostInfo(self):
|
|
return "cputype:16777223;cpusubtype:8;ostype:%s;vendor:apple;os_version:10.15.4;maccatalyst_version:13.4;endian:little;ptrsize:8;"%self.host_ostype
|
|
def qProcessInfo(self):
|
|
return "pid:a860;parent-pid:d2a0;real-uid:1f5;real-gid:14;effective-uid:1f5;effective-gid:14;cputype:1000007;cpusubtype:8;ptrsize:8;ostype:%s;vendor:apple;endian:little;"%self.process_ostype
|
|
def vCont(self):
|
|
return "vCont;"
|
|
|
|
def platform_test(self, host, process, expected_triple):
|
|
self.server.responder = self.MyResponder(host, process)
|
|
if self.TraceOn():
|
|
self.runCmd("log enable gdb-remote packets")
|
|
self.addTearDownHook(lambda: self.runCmd("log disable gdb-remote packets"))
|
|
|
|
target = self.dbg.CreateTargetWithFileAndArch(None, None)
|
|
process = self.connect(target)
|
|
triple = target.GetTriple()
|
|
self.assertEqual(triple, expected_triple)
|
|
|
|
@skipIfRemote
|
|
def test_macos(self):
|
|
self.platform_test(host="macosx", process="macosx",
|
|
expected_triple="x86_64h-apple-macosx-")
|
|
|
|
@skipIfRemote
|
|
def test_ios_sim(self):
|
|
self.platform_test(host="macosx", process="iossimulator",
|
|
expected_triple="x86_64h-apple-ios-simulator")
|
|
|
|
@skipIfRemote
|
|
def test_catalyst(self):
|
|
self.platform_test(host="macosx", process="maccatalyst",
|
|
expected_triple="x86_64h-apple-ios-macabi")
|
|
|
|
@skipIfRemote
|
|
def test_tvos_sim(self):
|
|
self.platform_test(host="macosx", process="tvossimulator",
|
|
expected_triple="x86_64h-apple-tvos-simulator")
|
|
|
|
@skipIfRemote
|
|
def test_tvos_sim(self):
|
|
self.platform_test(host="macosx", process="watchossimulator",
|
|
expected_triple="x86_64h-apple-watchos-simulator")
|