This is an ongoing series of commits that are reformatting our Python code. Reformatting is done with `black` (23.1.0). If you end up having problems merging this commit because you have made changes to a python file, the best way to handle that is to run `git checkout --ours <yourfile>` and then reformat it with black. RFC: https://discourse.llvm.org/t/rfc-document-and-standardize-python-code-style Differential revision: https://reviews.llvm.org/D151460
62 lines
2.0 KiB
Python
62 lines
2.0 KiB
Python
"""
|
|
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 *
|
|
from lldbsuite.test.decorators import *
|
|
|
|
|
|
class TestStopReasonAfterExpression(TestBase):
|
|
@skipIfWindows
|
|
@expectedFailureAll(oslist=["freebsd"], bugnumber="llvm.org/pr48415")
|
|
@expectedFlakeyNetBSD
|
|
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 different 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.assertSuccess(result.GetError(), "Expression failed")
|
|
|
|
stop_reason = other_thread.GetStopReason()
|
|
|
|
self.assertStopReason(
|
|
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",
|
|
)
|