Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 1 | """ |
| 2 | Test that we can successfully step into an STL function. |
| 3 | """ |
| 4 | |
| 5 | import os, time |
Johnny Chen | 7325883 | 2010-08-05 23:42:46 +0000 | [diff] [blame] | 6 | import unittest2 |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 7 | import lldb |
Johnny Chen | 1794184 | 2010-08-09 23:44:24 +0000 | [diff] [blame] | 8 | from lldbtest import * |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 9 | |
Johnny Chen | cbb4be0 | 2010-09-01 19:59:58 +0000 | [diff] [blame] | 10 | class STLTestCase(TestBase): |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 11 | |
| 12 | mydir = "stl" |
| 13 | |
Johnny Chen | 165a079 | 2010-09-07 18:27:35 +0000 | [diff] [blame] | 14 | @unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin") |
Johnny Chen | 165a079 | 2010-09-07 18:27:35 +0000 | [diff] [blame] | 15 | def test_with_dsym(self): |
| 16 | """Test that we can successfully step into an STL function.""" |
| 17 | self.buildDsym() |
| 18 | self.step_into_stl() |
| 19 | |
Johnny Chen | 165a079 | 2010-09-07 18:27:35 +0000 | [diff] [blame] | 20 | def test_with_dwarf(self): |
| 21 | """Test that we can successfully step into an STL function.""" |
| 22 | self.buildDwarf() |
| 23 | self.step_into_stl() |
| 24 | |
Johnny Chen | 77ca1a4 | 2010-10-12 22:53:02 +0000 | [diff] [blame^] | 25 | def setUp(self): |
| 26 | super(STLTestCase, self).setUp() |
| 27 | # Find the line number to break inside main(). |
| 28 | self.line = line_number('main.cpp', '// Set break point at this line.') |
| 29 | |
Johnny Chen | 165a079 | 2010-09-07 18:27:35 +0000 | [diff] [blame] | 30 | def step_into_stl(self): |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 31 | """Test that we can successfully step into an STL function.""" |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 32 | exe = os.path.join(os.getcwd(), "a.out") |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 33 | |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 34 | # The following two lines, if uncommented, will enable loggings. |
| 35 | #self.ci.HandleCommand("log enable -f /tmp/lldb.log lldb default", res) |
| 36 | #self.assertTrue(res.Succeeded()) |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 37 | |
| 38 | self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 39 | |
| 40 | # Break on line 13 of main.cpp. |
Johnny Chen | 77ca1a4 | 2010-10-12 22:53:02 +0000 | [diff] [blame^] | 41 | self.expect("breakpoint set -f main.cpp -l %d" % self.line, |
| 42 | BREAKPOINT_CREATED, |
| 43 | startstr = "Breakpoint created: 1: file ='main.cpp', line = %d" % |
| 44 | self.line) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 45 | |
Johnny Chen | 5ee8819 | 2010-08-27 23:47:36 +0000 | [diff] [blame] | 46 | self.runCmd("run", RUN_SUCCEEDED) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 47 | |
| 48 | # Stop at 'std::string hello_world ("Hello World!");'. |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 49 | self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT, |
Johnny Chen | 77ca1a4 | 2010-10-12 22:53:02 +0000 | [diff] [blame^] | 50 | substrs = ['main.cpp:%d' % self.line, |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 51 | 'stop reason = breakpoint']) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 52 | |
| 53 | # The breakpoint should have a hit count of 1. |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 54 | self.expect("breakpoint list", BREAKPOINT_HIT_ONCE, |
| 55 | substrs = [' resolved, hit count = 1']) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 56 | |
| 57 | # Now do 'thread step-in', we should stop on the basic_string template. |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 58 | # |
| 59 | # This assertion currently always fails. |
Johnny Chen | 588ddc1 | 2010-07-28 22:00:42 +0000 | [diff] [blame] | 60 | # This might be related: rdar://problem/8247112. |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 61 | # |
Johnny Chen | d0190a6 | 2010-08-23 17:10:44 +0000 | [diff] [blame] | 62 | #self.runCmd("thread step-in", trace=True) |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 63 | self.runCmd("thread step-in") |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 64 | |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 65 | self.expect("thread backtrace", "We have stepped in STL", |
| 66 | substrs = ['[inlined]', |
| 67 | 'basic_string.h']) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 68 | |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 69 | |
| 70 | if __name__ == '__main__': |
Johnny Chen | a212495 | 2010-08-05 21:23:45 +0000 | [diff] [blame] | 71 | import atexit |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 72 | lldb.SBDebugger.Initialize() |
Johnny Chen | a212495 | 2010-08-05 21:23:45 +0000 | [diff] [blame] | 73 | atexit.register(lambda: lldb.SBDebugger.Terminate()) |
Johnny Chen | 7325883 | 2010-08-05 23:42:46 +0000 | [diff] [blame] | 74 | unittest2.main() |