diff options
author | Johnny Chen <johnny.chen@apple.com> | 2011-03-09 23:45:56 +0000 |
---|---|---|
committer | Johnny Chen <johnny.chen@apple.com> | 2011-03-09 23:45:56 +0000 |
commit | a460316d817d0c4654b8e9f3df8ca49ca8b077da (patch) | |
tree | 5294fa018b766763695e47ad0cc057e24e153b3a /lldb/test/python_api/thread | |
parent | 334b2136f6ac5e3f7678be8d236924d70c513e62 (diff) | |
download | bcm5719-llvm-a460316d817d0c4654b8e9f3df8ca49ca8b077da.tar.gz bcm5719-llvm-a460316d817d0c4654b8e9f3df8ca49ca8b077da.zip |
Add test cases for Python SBThread.StepOut() API by stepping out of a malloc call where the call site is at function b().
Verifies that after the thread.StepOut(), we are at the correct line within function b.
llvm-svn: 127374
Diffstat (limited to 'lldb/test/python_api/thread')
-rw-r--r-- | lldb/test/python_api/thread/Makefile | 2 | ||||
-rw-r--r-- | lldb/test/python_api/thread/TestThreadAPI.py | 57 | ||||
-rw-r--r-- | lldb/test/python_api/thread/main2.cpp | 54 |
3 files changed, 111 insertions, 2 deletions
diff --git a/lldb/test/python_api/thread/Makefile b/lldb/test/python_api/thread/Makefile index 8a7102e347a..aa257ae2bd2 100644 --- a/lldb/test/python_api/thread/Makefile +++ b/lldb/test/python_api/thread/Makefile @@ -1,5 +1,5 @@ LEVEL = ../../make -CXX_SOURCES := main.cpp +CXX_SOURCES ?= main.cpp include $(LEVEL)/Makefile.rules diff --git a/lldb/test/python_api/thread/TestThreadAPI.py b/lldb/test/python_api/thread/TestThreadAPI.py index fa1e8eab2af..1a67f571f4c 100644 --- a/lldb/test/python_api/thread/TestThreadAPI.py +++ b/lldb/test/python_api/thread/TestThreadAPI.py @@ -5,7 +5,7 @@ Test SBThread APIs. import os, time import unittest2 import lldb -from lldbutil import get_stopped_thread +from lldbutil import get_stopped_thread, get_caller_symbol from lldbtest import * class ThreadAPITestCase(TestBase): @@ -25,11 +25,32 @@ class ThreadAPITestCase(TestBase): self.buildDwarf() self.get_stop_description() + @unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin") + @python_api_test + def test_step_out_of_malloc_into_function_b_with_dsym(self): + """Test Python SBThread.StepOut() API to step out of a malloc call where the call site is at function b().""" + # We build a different executable than the default buildDsym() does. + d = {'CXX_SOURCES': 'main2.cpp'} + self.buildDsym(dictionary=d) + self.setTearDownCleanup(dictionary=d) + self.step_out_of_malloc_into_function_b() + + @python_api_test + def test_step_out_of_malloc_into_function_b_with_dwarf(self): + """Test Python SBThread.StepOut() API to step out of a malloc call where the call site is at function b().""" + # We build a different executable than the default buildDwarf() does. + d = {'CXX_SOURCES': 'main2.cpp'} + self.buildDwarf(dictionary=d) + self.setTearDownCleanup(dictionary=d) + self.step_out_of_malloc_into_function_b() + def setUp(self): # Call super's setUp(). TestBase.setUp(self) # Find the line number to break inside main(). self.line = line_number("main.cpp", "// Set break point at this line and check variable 'my_char'.") + # Find the line number within main2.cpp for step_out_of_malloc_into_function_b(). + self.line2 = line_number("main2.cpp", "// thread step-out of malloc into function b.") def get_stop_description(self): """Test Python SBProcess.ReadMemory() API.""" @@ -58,6 +79,40 @@ class ThreadAPITestCase(TestBase): self.expect(stop_description, exe=False, startstr = 'breakpoint') + def step_out_of_malloc_into_function_b(self): + """Test Python SBThread.StepOut() API to step out of a malloc call where the call site is at function b().""" + exe = os.path.join(os.getcwd(), "a.out") + self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET) + + target = self.dbg.CreateTarget(exe) + self.assertTrue(target.IsValid(), VALID_TARGET) + + breakpoint = target.BreakpointCreateByName('malloc') + self.assertTrue(breakpoint.IsValid(), VALID_BREAKPOINT) + self.runCmd("breakpoint list") + + # Launch the process, and do not stop at the entry point. + error = lldb.SBError() + self.process = target.Launch (self.dbg.GetListener(), None, None, os.ctermid(), os.ctermid(), os.ctermid(), None, 0, False, error) + + thread = get_stopped_thread(self.process, lldb.eStopReasonBreakpoint) + self.assertTrue(thread != None, "There should be a thread stopped due to breakpoint") + self.runCmd("process status") + symbol = get_caller_symbol(thread) + caller = symbol.split('(')[0] + + while caller != "b": + #self.runCmd("thread backtrace") + #self.runCmd("process status") + self.process.Continue() + thread = get_stopped_thread(self.process, lldb.eStopReasonBreakpoint) + symbol = get_caller_symbol(thread) + caller = symbol.split('(')[0] + self.assertTrue(thread != None, "There should be a thread stopped due to breakpoint") + + thread.StepOut() + self.assertTrue(thread.GetFrameAtIndex(0).GetLineEntry().GetLine() == self.line2, + "step out of malloc into function b is successful") if __name__ == '__main__': import atexit diff --git a/lldb/test/python_api/thread/main2.cpp b/lldb/test/python_api/thread/main2.cpp new file mode 100644 index 00000000000..8a26b007b76 --- /dev/null +++ b/lldb/test/python_api/thread/main2.cpp @@ -0,0 +1,54 @@ +//===-- main.c --------------------------------------------------*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +#include <stdio.h> +#include <stdlib.h> + +int a(int); +int b(int); +int c(int); + +int a(int val) +{ + if (val <= 1) + return b(val); + else if (val >= 3) + return c(val); + + return val; +} + +int b(int val) +{ + int rc = c(val); + void *ptr = malloc(1024); // thread step-out of malloc into function b. + if (!ptr) + return -1; + else + printf("ptr=%p\n", ptr); + return rc; +} + +int c(int val) +{ + return val + 3; +} + +int main (int argc, char const *argv[]) +{ + int A1 = a(1); + printf("a(1) returns %d\n", A1); + + int B2 = b(2); + printf("b(2) returns %d\n", B2); + + int A3 = a(3); + printf("a(3) returns %d\n", A3); + + return 0; +} |