[Lldb-commits] [lldb] f4d4273 - Add a test for preserving state on the non-expr thread across expression evaluation.
Jim Ingham via lldb-commits
lldb-commits at lists.llvm.org
Wed Jun 3 14:31:52 PDT 2020
Author: Jim Ingham
Date: 2020-06-03T14:30:35-07:00
New Revision: f4d427326539f007b05378eaf66018c10b651ad0
URL: https://github.com/llvm/llvm-project/commit/f4d427326539f007b05378eaf66018c10b651ad0
DIFF: https://github.com/llvm/llvm-project/commit/f4d427326539f007b05378eaf66018c10b651ad0.diff
LOG: Add a test for preserving state on the non-expr thread across expression evaluation.
There may be another test that tests this but I couldn't find one.
Added:
lldb/test/API/functionalities/thread/state_after_expression/Makefile
lldb/test/API/functionalities/thread/state_after_expression/TestStateAfterExpression.py
lldb/test/API/functionalities/thread/state_after_expression/main.cpp
Modified:
Removed:
################################################################################
diff --git a/lldb/test/API/functionalities/thread/state_after_expression/Makefile b/lldb/test/API/functionalities/thread/state_after_expression/Makefile
new file mode 100644
index 000000000000..d7aace51bc82
--- /dev/null
+++ b/lldb/test/API/functionalities/thread/state_after_expression/Makefile
@@ -0,0 +1,6 @@
+CXX_SOURCES := main.cpp
+CFLAGS_EXTRAS := -std=c++11
+
+ENABLE_THREADS := YES
+
+include Makefile.rules
diff --git a/lldb/test/API/functionalities/thread/state_after_expression/TestStateAfterExpression.py b/lldb/test/API/functionalities/thread/state_after_expression/TestStateAfterExpression.py
new file mode 100644
index 000000000000..082b556dbdce
--- /dev/null
+++ b/lldb/test/API/functionalities/thread/state_after_expression/TestStateAfterExpression.py
@@ -0,0 +1,53 @@
+"""
+Make sure the stop reason of a thread that did not run
+during an expression is not changed by running the expression
+"""
+
+
+
+import lldb
+import lldbsuite.test.lldbutil as lldbutil
+from lldbsuite.test.lldbtest import *
+
+
+class TestStopReasonAfterExpression(TestBase):
+
+ mydir = TestBase.compute_mydir(__file__)
+
+ def test_thread_state_after_expr(self):
+ self.build()
+ self.main_source_file = lldb.SBFileSpec("main.cpp")
+ self.do_test()
+
+ def do_test(self):
+ (target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(self,
+ "Set a breakpoint here", self.main_source_file)
+
+ self.assertEqual(bkpt.GetNumLocations(), 2, "Got two locations")
+
+ # So now thread holds the main thread. Continue to hit the
+ # breakpoint again on the spawned thread:
+
+ threads = lldbutil.continue_to_breakpoint(process, bkpt)
+ self.assertEqual(len(threads), 1, "Hit the breakpoint the second time")
+ other_thread = threads[0]
+
+ self.assertNotEqual(thread.GetThreadID(), other_thread.GetThreadID(),
+ "A
diff erent thread")
+ # Run an expression ONLY on other_thread. Don't let thread run:
+ options = lldb.SBExpressionOptions()
+ options.SetTryAllThreads(False)
+ options.SetStopOthers(True)
+
+ result = thread.frames[0].EvaluateExpression('(int) printf("Hello\\n")', options)
+ self.assertTrue(result.GetError().Success(),
+ "Expression failed: '%s'"%(result.GetError().GetCString()))
+
+ stop_reason = other_thread.GetStopReason()
+
+ self.assertEqual(stop_reason, lldb.eStopReasonBreakpoint,
+ "Still records stopped at breakpoint: %s"
+ %(lldbutil.stop_reason_to_str(stop_reason)))
+ self.assertEqual(other_thread.GetStopReasonDataAtIndex(0), 1,
+ "Still records stopped at right breakpoint")
+
diff --git a/lldb/test/API/functionalities/thread/state_after_expression/main.cpp b/lldb/test/API/functionalities/thread/state_after_expression/main.cpp
new file mode 100644
index 000000000000..338232ece632
--- /dev/null
+++ b/lldb/test/API/functionalities/thread/state_after_expression/main.cpp
@@ -0,0 +1,14 @@
+#include <thread>
+
+void thread_func() {
+ // Set a breakpoint here
+}
+
+int
+main()
+{
+ // Set a breakpoint here
+ std::thread stopped_thread(thread_func);
+ stopped_thread.join();
+ return 0;
+}
More information about the lldb-commits
mailing list