2014-08-27 01:19:10 +08:00
|
|
|
import gdbremote_testcase
|
|
|
|
import lldbgdbserverutils
|
2014-08-27 02:21:02 +08:00
|
|
|
import sys
|
|
|
|
import unittest2
|
2014-08-27 01:19:10 +08:00
|
|
|
|
|
|
|
from lldbtest import *
|
|
|
|
|
|
|
|
class TestGdbRemoteProcessInfo(gdbremote_testcase.GdbRemoteTestCaseBase):
|
|
|
|
|
|
|
|
def qProcessInfo_returns_running_process(self):
|
|
|
|
procs = self.prep_debug_monitor_and_inferior()
|
|
|
|
self.add_process_info_collection_packets()
|
|
|
|
|
|
|
|
# Run the stream
|
|
|
|
context = self.expect_gdbremote_sequence()
|
|
|
|
self.assertIsNotNone(context)
|
|
|
|
|
|
|
|
# Gather process info response
|
|
|
|
process_info = self.parse_process_info_response(context)
|
|
|
|
self.assertIsNotNone(process_info)
|
|
|
|
|
|
|
|
# Ensure the process id looks reasonable.
|
|
|
|
pid_text = process_info.get("pid")
|
|
|
|
self.assertIsNotNone(pid_text)
|
|
|
|
pid = int(pid_text, base=16)
|
|
|
|
self.assertNotEqual(0, pid)
|
|
|
|
|
|
|
|
# If possible, verify that the process is running.
|
|
|
|
self.assertTrue(lldbgdbserverutils.process_is_running(pid, True))
|
|
|
|
|
|
|
|
@debugserver_test
|
|
|
|
@dsym_test
|
|
|
|
def test_qProcessInfo_returns_running_process_debugserver_dsym(self):
|
|
|
|
self.init_debugserver_test()
|
|
|
|
self.buildDsym()
|
|
|
|
self.qProcessInfo_returns_running_process()
|
|
|
|
|
|
|
|
@llgs_test
|
|
|
|
@dwarf_test
|
|
|
|
def test_qProcessInfo_returns_running_process_llgs_dwarf(self):
|
|
|
|
self.init_llgs_test()
|
|
|
|
self.buildDwarf()
|
|
|
|
self.qProcessInfo_returns_running_process()
|
|
|
|
|
|
|
|
def attach_commandline_qProcessInfo_reports_correct_pid(self):
|
|
|
|
procs = self.prep_debug_monitor_and_inferior()
|
|
|
|
self.assertIsNotNone(procs)
|
|
|
|
self.add_process_info_collection_packets()
|
|
|
|
|
|
|
|
# Run the stream
|
|
|
|
context = self.expect_gdbremote_sequence()
|
|
|
|
self.assertIsNotNone(context)
|
|
|
|
|
|
|
|
# Gather process info response
|
|
|
|
process_info = self.parse_process_info_response(context)
|
|
|
|
self.assertIsNotNone(process_info)
|
|
|
|
|
|
|
|
# Ensure the process id matches what we expected.
|
|
|
|
pid_text = process_info.get('pid', None)
|
|
|
|
self.assertIsNotNone(pid_text)
|
|
|
|
reported_pid = int(pid_text, base=16)
|
|
|
|
self.assertEqual(reported_pid, procs["inferior"].pid)
|
|
|
|
|
|
|
|
@debugserver_test
|
|
|
|
@dsym_test
|
|
|
|
def test_attach_commandline_qProcessInfo_reports_correct_pid_debugserver_dsym(self):
|
|
|
|
self.init_debugserver_test()
|
|
|
|
self.buildDsym()
|
|
|
|
self.set_inferior_startup_attach()
|
|
|
|
self.attach_commandline_qProcessInfo_reports_correct_pid()
|
|
|
|
|
|
|
|
@llgs_test
|
|
|
|
@dwarf_test
|
|
|
|
def test_attach_commandline_qProcessInfo_reports_correct_pid_llgs_dwarf(self):
|
|
|
|
self.init_llgs_test()
|
|
|
|
self.buildDwarf()
|
|
|
|
self.set_inferior_startup_attach()
|
|
|
|
self.attach_commandline_qProcessInfo_reports_correct_pid()
|
|
|
|
|
|
|
|
def qProcessInfo_reports_valid_endian(self):
|
|
|
|
procs = self.prep_debug_monitor_and_inferior()
|
|
|
|
self.add_process_info_collection_packets()
|
|
|
|
|
|
|
|
# Run the stream
|
|
|
|
context = self.expect_gdbremote_sequence()
|
|
|
|
self.assertIsNotNone(context)
|
|
|
|
|
|
|
|
# Gather process info response
|
|
|
|
process_info = self.parse_process_info_response(context)
|
|
|
|
self.assertIsNotNone(process_info)
|
|
|
|
|
|
|
|
# Ensure the process id looks reasonable.
|
|
|
|
endian = process_info.get("endian")
|
|
|
|
self.assertIsNotNone(endian)
|
|
|
|
self.assertTrue(endian in ["little", "big", "pdp"])
|
|
|
|
|
|
|
|
@debugserver_test
|
|
|
|
@dsym_test
|
|
|
|
def test_qProcessInfo_reports_valid_endian_debugserver_dsym(self):
|
|
|
|
self.init_debugserver_test()
|
|
|
|
self.buildDsym()
|
|
|
|
self.qProcessInfo_reports_valid_endian()
|
|
|
|
|
|
|
|
@llgs_test
|
|
|
|
@dwarf_test
|
|
|
|
def test_qProcessInfo_reports_valid_endian_llgs_dwarf(self):
|
|
|
|
self.init_llgs_test()
|
|
|
|
self.buildDwarf()
|
|
|
|
self.qProcessInfo_reports_valid_endian()
|
|
|
|
|
2014-08-27 02:21:02 +08:00
|
|
|
def qProcessInfo_contains_keys(self, expected_key_set):
|
|
|
|
procs = self.prep_debug_monitor_and_inferior()
|
|
|
|
self.add_process_info_collection_packets()
|
|
|
|
|
|
|
|
# Run the stream
|
|
|
|
context = self.expect_gdbremote_sequence()
|
|
|
|
self.assertIsNotNone(context)
|
|
|
|
|
|
|
|
# Gather process info response
|
|
|
|
process_info = self.parse_process_info_response(context)
|
|
|
|
self.assertIsNotNone(process_info)
|
|
|
|
|
|
|
|
# Ensure the expected keys are present and non-None within the process info.
|
|
|
|
missing_key_set = set()
|
|
|
|
for expected_key in expected_key_set:
|
|
|
|
if expected_key not in process_info:
|
|
|
|
missing_key_set.add(expected_key)
|
|
|
|
|
|
|
|
self.assertEquals(missing_key_set, set(), "the listed keys are missing in the qProcessInfo result")
|
|
|
|
|
2014-08-27 02:40:56 +08:00
|
|
|
def qProcessInfo_does_not_contain_keys(self, absent_key_set):
|
|
|
|
procs = self.prep_debug_monitor_and_inferior()
|
|
|
|
self.add_process_info_collection_packets()
|
|
|
|
|
|
|
|
# Run the stream
|
|
|
|
context = self.expect_gdbremote_sequence()
|
|
|
|
self.assertIsNotNone(context)
|
|
|
|
|
|
|
|
# Gather process info response
|
|
|
|
process_info = self.parse_process_info_response(context)
|
|
|
|
self.assertIsNotNone(process_info)
|
|
|
|
|
|
|
|
# Ensure the unexpected keys are not present
|
|
|
|
unexpected_key_set = set()
|
|
|
|
for unexpected_key in absent_key_set:
|
|
|
|
if unexpected_key in process_info:
|
|
|
|
unexpected_key_set.add(unexpected_key)
|
|
|
|
|
|
|
|
self.assertEquals(unexpected_key_set, set(), "the listed keys were present but unexpected in qProcessInfo result")
|
|
|
|
|
2014-08-27 02:21:02 +08:00
|
|
|
@unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
|
|
|
|
@debugserver_test
|
|
|
|
@dsym_test
|
|
|
|
def test_qProcessInfo_contains_cputype_cpusubtype_debugserver_darwin(self):
|
|
|
|
self.init_debugserver_test()
|
|
|
|
self.buildDsym()
|
|
|
|
self.qProcessInfo_contains_keys(set(['cputype', 'cpusubtype']))
|
|
|
|
|
|
|
|
@unittest2.skipUnless(sys.platform.startswith("linux"), "requires Linux")
|
|
|
|
@llgs_test
|
|
|
|
@dwarf_test
|
|
|
|
def test_qProcessInfo_contains_triple_llgs_linux(self):
|
|
|
|
self.init_llgs_test()
|
|
|
|
self.buildDwarf()
|
|
|
|
self.qProcessInfo_contains_keys(set(['triple']))
|
|
|
|
|
2014-08-27 02:40:56 +08:00
|
|
|
@unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
|
|
|
|
@debugserver_test
|
|
|
|
@dsym_test
|
|
|
|
def test_qProcessInfo_does_not_contain_triple_debugserver_darwin(self):
|
|
|
|
self.init_debugserver_test()
|
|
|
|
self.buildDsym()
|
|
|
|
# We don't expect to see triple on darwin. If we do, we'll prefer triple
|
|
|
|
# to cputype/cpusubtype and skip some darwin-based ProcessGDBRemote ArchSpec setup
|
|
|
|
# for the remote Host and Process.
|
|
|
|
self.qProcessInfo_does_not_contain_keys(set(['triple']))
|
|
|
|
|
|
|
|
@unittest2.skipUnless(sys.platform.startswith("linux"), "requires Linux")
|
|
|
|
@llgs_test
|
|
|
|
@dwarf_test
|
|
|
|
def test_qProcessInfo_does_not_contain_cputype_cpusubtype_llgs_linux(self):
|
|
|
|
self.init_llgs_test()
|
|
|
|
self.buildDwarf()
|
|
|
|
self.qProcessInfo_does_not_contain_keys(set(['cputype', 'cpusubtype']))
|
|
|
|
|
2014-08-27 01:19:10 +08:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest2.main()
|