Files
clang-p2996/lldb/test/API/functionalities/step-vrs-interrupt/TestStepVrsInterruptTimeout.py
Jonas Devlieghere 2238dcc393 [NFC][Py Reformat] Reformat python files in lldb
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
2023-05-25 12:54:09 -07:00

37 lines
1.3 KiB
Python

"""
This is to make sure that the interrupt timer
doesn't influence synchronous user level stepping.
"""
import lldb
import lldbsuite.test.lldbutil as lldbutil
from lldbsuite.test.lldbtest import *
class TestStepVrsInterruptTimeout(TestBase):
NO_DEBUG_INFO_TESTCASE = True
def test_step_vrs_interrupt(self):
"""This test is to make sure that the interrupt timeout
doesn't cause use to flub events from a synchronous step."""
self.build()
self.main_source_file = lldb.SBFileSpec("main.cpp")
self.sample_test()
def sample_test(self):
"""You might use the test implementation in several ways, say so here."""
# This function starts a process, "a.out" by default, sets a source
# breakpoint, runs to it, and returns the thread, process & target.
# It optionally takes an SBLaunchOption argument if you want to pass
# arguments or environment variables.
(target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(
self, "Set a breakpoint here", self.main_source_file
)
self.dbg.SetAsync(False)
self.runCmd("settings set target.process.interrupt-timeout 1")
thread.StepOver()
self.assertState(
process.GetState(), lldb.eStateStopped, "Stopped like we should"
)