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 | |
Johnny Chen | 8d798eb | 2011-06-25 21:07:03 +0000 | [diff] [blame^] | 12 | mydir = os.path.join("lang", "cpp", "stl") |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 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): |
Johnny Chen | aadcef5 | 2010-10-14 17:31:24 +0000 | [diff] [blame] | 26 | # Call super's setUp(). |
| 27 | TestBase.setUp(self) |
Johnny Chen | 77ca1a4 | 2010-10-12 22:53:02 +0000 | [diff] [blame] | 28 | # Find the line number to break inside main(). |
| 29 | self.line = line_number('main.cpp', '// Set break point at this line.') |
| 30 | |
Johnny Chen | 165a079 | 2010-09-07 18:27:35 +0000 | [diff] [blame] | 31 | def step_into_stl(self): |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 32 | """Test that we can successfully step into an STL function.""" |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 33 | exe = os.path.join(os.getcwd(), "a.out") |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 34 | |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 35 | # The following two lines, if uncommented, will enable loggings. |
| 36 | #self.ci.HandleCommand("log enable -f /tmp/lldb.log lldb default", res) |
| 37 | #self.assertTrue(res.Succeeded()) |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 38 | |
| 39 | self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 40 | |
Johnny Chen | 78c0aeb | 2010-10-12 23:01:50 +0000 | [diff] [blame] | 41 | # rdar://problem/8543077 |
| 42 | # test/stl: clang built binaries results in the breakpoint locations = 3, |
| 43 | # is this a problem with clang generated debug info? |
| 44 | # |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 45 | # Break on line 13 of main.cpp. |
Johnny Chen | 77ca1a4 | 2010-10-12 22:53:02 +0000 | [diff] [blame] | 46 | self.expect("breakpoint set -f main.cpp -l %d" % self.line, |
| 47 | BREAKPOINT_CREATED, |
| 48 | startstr = "Breakpoint created: 1: file ='main.cpp', line = %d" % |
| 49 | self.line) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 50 | |
Johnny Chen | 5ee8819 | 2010-08-27 23:47:36 +0000 | [diff] [blame] | 51 | self.runCmd("run", RUN_SUCCEEDED) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 52 | |
| 53 | # Stop at 'std::string hello_world ("Hello World!");'. |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 54 | self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT, |
Johnny Chen | 77ca1a4 | 2010-10-12 22:53:02 +0000 | [diff] [blame] | 55 | substrs = ['main.cpp:%d' % self.line, |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 56 | 'stop reason = breakpoint']) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 57 | |
| 58 | # The breakpoint should have a hit count of 1. |
Caroline Tice | 79042b3 | 2011-02-04 22:59:41 +0000 | [diff] [blame] | 59 | self.expect("breakpoint list -f", BREAKPOINT_HIT_ONCE, |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 60 | substrs = [' resolved, hit count = 1']) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 61 | |
Johnny Chen | 1b96c1e | 2011-05-16 23:24:17 +0000 | [diff] [blame] | 62 | # Now do 'thread step-in', if we have successfully stopped, we should |
| 63 | # stop due to the reason of "step in". |
Johnny Chen | ff3d01d | 2010-08-20 21:03:09 +0000 | [diff] [blame] | 64 | self.runCmd("thread step-in") |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 65 | |
Johnny Chen | 1b96c1e | 2011-05-16 23:24:17 +0000 | [diff] [blame] | 66 | self.runCmd("process status") |
| 67 | if "stopped" in self.res.GetOutput(): |
| 68 | self.expect("thread backtrace", "We have successfully stepped in", |
| 69 | substrs = ['stop reason = step in']) |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 70 | |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 71 | |
| 72 | if __name__ == '__main__': |
Johnny Chen | a212495 | 2010-08-05 21:23:45 +0000 | [diff] [blame] | 73 | import atexit |
Johnny Chen | 377a8ed | 2010-07-28 21:24:31 +0000 | [diff] [blame] | 74 | lldb.SBDebugger.Initialize() |
Johnny Chen | a212495 | 2010-08-05 21:23:45 +0000 | [diff] [blame] | 75 | atexit.register(lambda: lldb.SBDebugger.Terminate()) |
Johnny Chen | 7325883 | 2010-08-05 23:42:46 +0000 | [diff] [blame] | 76 | unittest2.main() |