diff options
| author | Johnny Chen <johnny.chen@apple.com> | 2010-07-28 21:24:31 +0000 |
|---|---|---|
| committer | Johnny Chen <johnny.chen@apple.com> | 2010-07-28 21:24:31 +0000 |
| commit | 377a8ed91339e3c60a4d203bf30fa6b5c6f88918 (patch) | |
| tree | c059c5737cb2ea98025acfa24af55061d25b54fd | |
| parent | 85ffddc1bfbe636cdd62f13a453467e09b7f9c5d (diff) | |
| download | bcm5719-llvm-377a8ed91339e3c60a4d203bf30fa6b5c6f88918.tar.gz bcm5719-llvm-377a8ed91339e3c60a4d203bf30fa6b5c6f88918.zip | |
Added a test case to test that we can successfully step into an STL function.
This test case currently always fails.
llvm-svn: 109674
| -rw-r--r-- | lldb/test/stl/TestSTL.py | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/lldb/test/stl/TestSTL.py b/lldb/test/stl/TestSTL.py new file mode 100644 index 00000000000..145ec6ab6be --- /dev/null +++ b/lldb/test/stl/TestSTL.py @@ -0,0 +1,75 @@ +""" +Test that we can successfully step into an STL function. +""" + +import os, time +import unittest +import lldb +import lldbtest +import time + +class TestSTL(lldbtest.TestBase): + + mydir = "stl" + + def test_step_into_stl(self): + """Test that we can successfully step into an STL function.""" + res = self.res + exe = os.path.join(os.getcwd(), "a.out") + # 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()) + self.ci.HandleCommand("file " + exe, res) + self.assertTrue(res.Succeeded()) + + # Break on line 13 of main.cpp. + self.ci.HandleCommand("breakpoint set -f main.cpp -l 13", res) + self.assertTrue(res.Succeeded()) + self.assertTrue(res.GetOutput().startswith( + "Breakpoint created: 1: file ='main.cpp', line = 13, locations = 1") + ) + + self.ci.HandleCommand("run", res) + time.sleep(0.1) + self.assertTrue(res.Succeeded()) + + # Stop at 'std::string hello_world ("Hello World!");'. + self.ci.HandleCommand("thread list", res) + print "thread list ->", res.GetOutput() + self.assertTrue(res.Succeeded()) + output = res.GetOutput() + self.assertTrue(output.find('main.cpp:13') > 0 and + output.find('stop reason = breakpoint') > 0) + + # The breakpoint should have a hit count of 1. + self.ci.HandleCommand("breakpoint list", res) + self.assertTrue(res.Succeeded()) + self.assertTrue(res.GetOutput().find(' resolved, hit count = 1') > 0) + + # Now do 'thread step-in', we should stop on the basic_string template. + self.ci.HandleCommand("thread step-in", res) + print "thread step-in:", res.GetOutput() + + # + # This assertion currently always fails. + # + self.assertTrue(res.Succeeded()) + + #self.ci.HandleCommand("process status", res) + #print "process status:", res.GetOutput() + self.ci.HandleCommand("thread backtrace", res) + print "thread backtrace:", res.GetOutput() + self.assertTrue(res.Succeeded()) + output = res.GetOutput() + self.assertTrue(output.find('[inlined]') > 0 and + output.find('basic_string.h') and + output.find('stop reason = step in,') > 0) + + self.ci.HandleCommand("continue", res) + self.assertTrue(res.Succeeded()) + + +if __name__ == '__main__': + lldb.SBDebugger.Initialize() + unittest.main() + lldb.SBDebugger.Terminate() |

