diff options
| author | Enrico Granata <egranata@apple.com> | 2014-02-18 23:48:11 +0000 |
|---|---|---|
| committer | Enrico Granata <egranata@apple.com> | 2014-02-18 23:48:11 +0000 |
| commit | 08a04327a94bbfa0d2d804c4ee845ef8a7c6cf54 (patch) | |
| tree | 245831f7bd9e7a11cd0cbec41c32e520125d6c9f /lldb/test/python_api | |
| parent | 9873a5ba4f17c79b280596c4bbaf707b7d3011fb (diff) | |
| download | bcm5719-llvm-08a04327a94bbfa0d2d804c4ee845ef8a7c6cf54.tar.gz bcm5719-llvm-08a04327a94bbfa0d2d804c4ee845ef8a7c6cf54.zip | |
<rdar://problem/15960553>
Fix a bug where calling SBFrame::FindValue() would cause a copy of all variables in the block to be inserted in the frame's variable list, regardless of whether those same variables were there or not - which means one could end up with a frame with lots of duplicate copies of the same variables
llvm-svn: 201614
Diffstat (limited to 'lldb/test/python_api')
| -rw-r--r-- | lldb/test/python_api/findvalue_duplist/Makefile | 8 | ||||
| -rw-r--r-- | lldb/test/python_api/findvalue_duplist/TestSBFrameFindValue.py | 70 | ||||
| -rw-r--r-- | lldb/test/python_api/findvalue_duplist/main.cpp | 7 |
3 files changed, 85 insertions, 0 deletions
diff --git a/lldb/test/python_api/findvalue_duplist/Makefile b/lldb/test/python_api/findvalue_duplist/Makefile new file mode 100644 index 00000000000..ddffdcfb62d --- /dev/null +++ b/lldb/test/python_api/findvalue_duplist/Makefile @@ -0,0 +1,8 @@ +LEVEL = ../../make + +CXX_SOURCES := main.cpp + +# Clean renamed executable on 'make clean' +clean: OBJECTS+=no_synth + +include $(LEVEL)/Makefile.rules diff --git a/lldb/test/python_api/findvalue_duplist/TestSBFrameFindValue.py b/lldb/test/python_api/findvalue_duplist/TestSBFrameFindValue.py new file mode 100644 index 00000000000..accd88f94dd --- /dev/null +++ b/lldb/test/python_api/findvalue_duplist/TestSBFrameFindValue.py @@ -0,0 +1,70 @@ +"""Test that SBFrame::FindValue finds things but does not duplicate the entire variables list""" + +import os, sys, time +import unittest2 +import lldb +from lldbtest import * +import lldbutil + +class SBFrameFindValueTestCase(TestBase): + + mydir = TestBase.compute_mydir(__file__) + + @unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin") + @python_api_test + @dsym_test + def test_with_dsym_formatters_api(self): + """Test that SBFrame::FindValue finds things but does not duplicate the entire variables list""" + self.buildDsym() + self.setTearDownCleanup() + self.commands() + + @python_api_test + @dwarf_test + def test_with_dwarf_formatters_api(self): + """Test that SBFrame::FindValue finds things but does not duplicate the entire variables list""" + self.buildDwarf() + self.setTearDownCleanup() + self.commands() + + def setUp(self): + # Call super's setUp(). + TestBase.setUp(self) + + def commands(self): + """Test that SBFrame::FindValue finds things but does not duplicate the entire variables list""" + exe_name = "a.out" + exe = os.path.join(os.getcwd(), exe_name) + + # Create the target + target = self.dbg.CreateTarget(exe) + self.assertTrue(target, VALID_TARGET) + + # Set the breakpoints + breakpoint = target.BreakpointCreateBySourceRegex('Set breakpoint here', lldb.SBFileSpec("main.cpp")) + self.assertTrue(breakpoint.GetNumLocations() > 0, VALID_BREAKPOINT) + + # Launch the process, and do not stop at the entry point. + process = target.LaunchSimple(None, None, os.getcwd()) + + self.assertTrue(process, PROCESS_IS_VALID) + + # Frame #0 should be at our breakpoint. + threads = lldbutil.get_threads_stopped_at_breakpoint (process, breakpoint) + + self.assertTrue(len(threads) == 1) + self.thread = threads[0] + self.frame = self.thread.frames[0] + self.assertTrue(self.frame, "Frame 0 is valid.") + + self.assertTrue(self.frame.GetVariables(True,True,False,True).GetSize() == 2, "variable count is off") + self.assertFalse(self.frame.FindValue("NoSuchThing",lldb.eValueTypeVariableArgument,lldb.eDynamicCanRunTarget).IsValid(), "found something that should not be here") + self.assertTrue(self.frame.GetVariables(True,True,False,True).GetSize() == 2, "variable count is off after failed FindValue()") + self.assertTrue(self.frame.FindValue("a",lldb.eValueTypeVariableArgument,lldb.eDynamicCanRunTarget).IsValid(), "FindValue() didn't find an argument") + self.assertTrue(self.frame.GetVariables(True,True,False,True).GetSize() == 2, "variable count is off after successful FindValue()") + +if __name__ == '__main__': + import atexit + lldb.SBDebugger.Initialize() + atexit.register(lambda: lldb.SBDebugger.Terminate()) + unittest2.main() diff --git a/lldb/test/python_api/findvalue_duplist/main.cpp b/lldb/test/python_api/findvalue_duplist/main.cpp new file mode 100644 index 00000000000..7058d46b04a --- /dev/null +++ b/lldb/test/python_api/findvalue_duplist/main.cpp @@ -0,0 +1,7 @@ +int foo(int a, int b) { + return a + b; // Set breakpoint here +} + +int main() { + return foo(1,3); +} |

