summaryrefslogtreecommitdiffstats
path: root/lldb/test/python_api
diff options
context:
space:
mode:
authorEnrico Granata <egranata@apple.com>2014-02-18 23:48:11 +0000
committerEnrico Granata <egranata@apple.com>2014-02-18 23:48:11 +0000
commit08a04327a94bbfa0d2d804c4ee845ef8a7c6cf54 (patch)
tree245831f7bd9e7a11cd0cbec41c32e520125d6c9f /lldb/test/python_api
parent9873a5ba4f17c79b280596c4bbaf707b7d3011fb (diff)
downloadbcm5719-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/Makefile8
-rw-r--r--lldb/test/python_api/findvalue_duplist/TestSBFrameFindValue.py70
-rw-r--r--lldb/test/python_api/findvalue_duplist/main.cpp7
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);
+}
OpenPOWER on IntegriCloud