2013-05-22 05:55:59 +08:00
|
|
|
"""
|
|
|
|
Test some lldb command abbreviations.
|
|
|
|
"""
|
2015-10-24 01:04:29 +08:00
|
|
|
from __future__ import print_function
|
|
|
|
|
2015-11-04 03:20:39 +08:00
|
|
|
|
2015-10-23 04:06:20 +08:00
|
|
|
|
2013-05-22 05:55:59 +08:00
|
|
|
import lldb
|
|
|
|
import os
|
|
|
|
import time
|
2016-02-05 07:04:17 +08:00
|
|
|
from lldbsuite.support import seven
|
|
|
|
from lldbsuite.test.decorators import *
|
2015-11-03 10:06:18 +08:00
|
|
|
from lldbsuite.test.lldbtest import *
|
2016-02-05 07:04:17 +08:00
|
|
|
from lldbsuite.test import lldbutil
|
2013-05-22 05:55:59 +08:00
|
|
|
|
|
|
|
def execute_command (command):
|
2015-10-24 01:04:29 +08:00
|
|
|
#print('%% %s' % (command))
|
2015-11-04 02:55:22 +08:00
|
|
|
(exit_status, output) = seven.get_command_status_output(command)
|
2013-05-22 06:00:39 +08:00
|
|
|
#if output:
|
2015-10-24 01:04:29 +08:00
|
|
|
# print(output)
|
|
|
|
#print('status = %u' % (exit_status))
|
2013-05-22 05:55:59 +08:00
|
|
|
return exit_status
|
|
|
|
|
|
|
|
class ExecTestCase(TestBase):
|
|
|
|
|
2013-12-11 07:19:29 +08:00
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
2013-05-22 05:55:59 +08:00
|
|
|
|
2015-03-30 22:12:17 +08:00
|
|
|
@skipUnlessDarwin
|
2015-09-30 18:12:40 +08:00
|
|
|
def test(self):
|
2013-05-22 05:55:59 +08:00
|
|
|
if self.getArchitecture() == 'x86_64':
|
|
|
|
source = os.path.join (os.getcwd(), "main.cpp")
|
|
|
|
o_file = os.path.join (os.getcwd(), "main.o")
|
|
|
|
execute_command ("'%s' -g -O0 -arch i386 -arch x86_64 '%s' -c -o '%s'" % (os.environ["CC"], source, o_file))
|
|
|
|
execute_command ("'%s' -g -O0 -arch i386 -arch x86_64 '%s'" % (os.environ["CC"], o_file))
|
2015-09-30 18:12:40 +08:00
|
|
|
if self.debug_info != "dsym":
|
|
|
|
dsym_path = os.path.join (os.getcwd(), "a.out.dSYM")
|
|
|
|
execute_command ("rm -rf '%s'" % (dsym_path))
|
2013-05-22 05:55:59 +08:00
|
|
|
else:
|
2015-09-30 18:12:40 +08:00
|
|
|
self.build()
|
2013-05-22 05:55:59 +08:00
|
|
|
|
|
|
|
exe = os.path.join (os.getcwd(), "a.out")
|
|
|
|
|
|
|
|
# Create the target
|
|
|
|
target = self.dbg.CreateTarget(exe)
|
|
|
|
|
|
|
|
# Create any breakpoints we need
|
|
|
|
breakpoint = target.BreakpointCreateBySourceRegex ('Set breakpoint 1 here', lldb.SBFileSpec ("main.cpp", False))
|
|
|
|
self.assertTrue(breakpoint, VALID_BREAKPOINT)
|
|
|
|
|
|
|
|
# Launch the process
|
2013-12-14 03:18:59 +08:00
|
|
|
process = target.LaunchSimple (None, None, self.get_process_working_directory())
|
2013-05-22 05:55:59 +08:00
|
|
|
self.assertTrue(process, PROCESS_IS_VALID)
|
|
|
|
|
|
|
|
for i in range(6):
|
|
|
|
# The stop reason of the thread should be breakpoint.
|
|
|
|
self.assertTrue(process.GetState() == lldb.eStateStopped,
|
|
|
|
STOPPED_DUE_TO_BREAKPOINT)
|
|
|
|
|
2016-02-12 08:03:19 +08:00
|
|
|
threads = lldbutil.get_threads_stopped_at_breakpoint(process, breakpoint)
|
|
|
|
self.assertTrue(len(threads) == 1)
|
2013-05-22 05:55:59 +08:00
|
|
|
|
2016-02-12 08:03:19 +08:00
|
|
|
# We had a deadlock tearing down the TypeSystemMap on exec, but only if some
|
|
|
|
# expression had been evaluated. So make sure we do that here so the teardown
|
|
|
|
# is not trivial.
|
2013-05-22 05:55:59 +08:00
|
|
|
|
2016-02-12 08:03:19 +08:00
|
|
|
thread = threads[0]
|
|
|
|
value = thread.frames[0].EvaluateExpression("1 + 2")
|
|
|
|
self.assertTrue(value.IsValid(), "Expression evaluated successfully")
|
|
|
|
int_value = value.GetValueAsSigned()
|
|
|
|
self.assertTrue(int_value == 3, "Expression got the right result.")
|
2013-05-22 05:55:59 +08:00
|
|
|
|
|
|
|
# Run and we should stop due to exec
|
|
|
|
process.Continue()
|
|
|
|
|
|
|
|
self.assertTrue(process.GetState() == lldb.eStateStopped,
|
|
|
|
"Process should be stopped at __dyld_start")
|
|
|
|
|
2016-02-12 08:03:19 +08:00
|
|
|
threads = lldbutil.get_stopped_threads(process, lldb.eStopReasonExec)
|
|
|
|
self.assertTrue(len(threads) == 1, "We got a thread stopped for exec.")
|
|
|
|
|
2013-05-22 05:55:59 +08:00
|
|
|
# Run and we should stop at breakpoint in main after exec
|
2013-05-22 06:00:39 +08:00
|
|
|
process.Continue()
|
2016-02-12 08:03:19 +08:00
|
|
|
|
|
|
|
threads = lldbutil.get_threads_stopped_at_breakpoint(process, breakpoint)
|
|
|
|
self.assertTrue(len(threads) == 1, "Stopped at breakpoint in exec'ed process.")
|