2010-07-29 05:24:31 +08:00
|
|
|
"""
|
|
|
|
Test that we can successfully step into an STL function.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import os, time
|
2010-08-06 07:42:46 +08:00
|
|
|
import unittest2
|
2010-07-29 05:24:31 +08:00
|
|
|
import lldb
|
2010-08-10 07:44:24 +08:00
|
|
|
from lldbtest import *
|
2010-07-29 05:24:31 +08:00
|
|
|
|
2010-09-02 03:59:58 +08:00
|
|
|
class STLTestCase(TestBase):
|
2010-07-29 05:24:31 +08:00
|
|
|
|
|
|
|
mydir = "stl"
|
|
|
|
|
2010-09-08 02:27:35 +08:00
|
|
|
@unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
|
|
|
|
def test_with_dsym(self):
|
|
|
|
"""Test that we can successfully step into an STL function."""
|
|
|
|
self.buildDsym()
|
|
|
|
self.step_into_stl()
|
|
|
|
|
|
|
|
def test_with_dwarf(self):
|
|
|
|
"""Test that we can successfully step into an STL function."""
|
|
|
|
self.buildDwarf()
|
|
|
|
self.step_into_stl()
|
|
|
|
|
2010-10-13 06:53:02 +08:00
|
|
|
def setUp(self):
|
|
|
|
super(STLTestCase, self).setUp()
|
|
|
|
# Find the line number to break inside main().
|
|
|
|
self.line = line_number('main.cpp', '// Set break point at this line.')
|
|
|
|
|
2010-09-08 02:27:35 +08:00
|
|
|
def step_into_stl(self):
|
2010-07-29 05:24:31 +08:00
|
|
|
"""Test that we can successfully step into an STL function."""
|
|
|
|
exe = os.path.join(os.getcwd(), "a.out")
|
2010-08-21 05:03:09 +08:00
|
|
|
|
2010-07-29 05:24:31 +08:00
|
|
|
# The following two lines, if uncommented, will enable loggings.
|
|
|
|
#self.ci.HandleCommand("log enable -f /tmp/lldb.log lldb default", res)
|
|
|
|
#self.assertTrue(res.Succeeded())
|
2010-08-21 05:03:09 +08:00
|
|
|
|
|
|
|
self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
|
2010-07-29 05:24:31 +08:00
|
|
|
|
2010-10-13 07:01:50 +08:00
|
|
|
# rdar://problem/8543077
|
|
|
|
# test/stl: clang built binaries results in the breakpoint locations = 3,
|
|
|
|
# is this a problem with clang generated debug info?
|
|
|
|
#
|
2010-07-29 05:24:31 +08:00
|
|
|
# Break on line 13 of main.cpp.
|
2010-10-13 06:53:02 +08:00
|
|
|
self.expect("breakpoint set -f main.cpp -l %d" % self.line,
|
|
|
|
BREAKPOINT_CREATED,
|
|
|
|
startstr = "Breakpoint created: 1: file ='main.cpp', line = %d" %
|
|
|
|
self.line)
|
2010-07-29 05:24:31 +08:00
|
|
|
|
2010-08-28 07:47:36 +08:00
|
|
|
self.runCmd("run", RUN_SUCCEEDED)
|
2010-07-29 05:24:31 +08:00
|
|
|
|
|
|
|
# Stop at 'std::string hello_world ("Hello World!");'.
|
2010-08-21 05:03:09 +08:00
|
|
|
self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
|
2010-10-13 06:53:02 +08:00
|
|
|
substrs = ['main.cpp:%d' % self.line,
|
2010-08-21 05:03:09 +08:00
|
|
|
'stop reason = breakpoint'])
|
2010-07-29 05:24:31 +08:00
|
|
|
|
|
|
|
# The breakpoint should have a hit count of 1.
|
2010-08-21 05:03:09 +08:00
|
|
|
self.expect("breakpoint list", BREAKPOINT_HIT_ONCE,
|
|
|
|
substrs = [' resolved, hit count = 1'])
|
2010-07-29 05:24:31 +08:00
|
|
|
|
|
|
|
# Now do 'thread step-in', we should stop on the basic_string template.
|
|
|
|
#
|
|
|
|
# This assertion currently always fails.
|
2010-07-29 06:00:42 +08:00
|
|
|
# This might be related: rdar://problem/8247112.
|
2010-07-29 05:24:31 +08:00
|
|
|
#
|
2010-08-24 01:10:44 +08:00
|
|
|
#self.runCmd("thread step-in", trace=True)
|
2010-08-21 05:03:09 +08:00
|
|
|
self.runCmd("thread step-in")
|
2010-07-29 05:24:31 +08:00
|
|
|
|
2010-08-21 05:03:09 +08:00
|
|
|
self.expect("thread backtrace", "We have stepped in STL",
|
|
|
|
substrs = ['[inlined]',
|
|
|
|
'basic_string.h'])
|
2010-07-29 05:24:31 +08:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2010-08-06 05:23:45 +08:00
|
|
|
import atexit
|
2010-07-29 05:24:31 +08:00
|
|
|
lldb.SBDebugger.Initialize()
|
2010-08-06 05:23:45 +08:00
|
|
|
atexit.register(lambda: lldb.SBDebugger.Terminate())
|
2010-08-06 07:42:46 +08:00
|
|
|
unittest2.main()
|