Add a new decorator `skipIfTargetDoesNotSupportThreads` to skip tests that use threading. This is motivated by running the test suite targeting WebAssembly, where `wasip1` does not support threads. There are variants that do support threading (e.g. `wasip1-threading`) that the current implementation accounts for.
138 lines
5.3 KiB
Python
138 lines
5.3 KiB
Python
"""Test the lldb public C++ api breakpoint callbacks."""
|
|
|
|
import os
|
|
import subprocess
|
|
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
@skipIfTargetDoesNotSupportThreads()
|
|
@skipIfNoSBHeaders
|
|
class SBBreakpointCallbackCase(TestBase):
|
|
SHARED_BUILD_TESTCASE = False
|
|
NO_DEBUG_INFO_TESTCASE = True
|
|
|
|
def setUp(self):
|
|
TestBase.setUp(self)
|
|
self.generateSource("driver.cpp")
|
|
self.generateSource("listener_test.cpp")
|
|
self.generateSource("test_breakpoint_callback.cpp")
|
|
self.generateSource("test_breakpoint_location_callback.cpp")
|
|
self.generateSource("test_listener_event_description.cpp")
|
|
self.generateSource("test_listener_event_process_state.cpp")
|
|
self.generateSource("test_listener_resume.cpp")
|
|
self.generateSource("test_stop-hook.cpp")
|
|
self.generateSource("test_concurrent_unwind.cpp")
|
|
|
|
@skipIfRemote
|
|
# clang-cl does not support throw or catch (llvm.org/pr24538)
|
|
@skipIfWindows
|
|
@skipIfHostIncompatibleWithTarget
|
|
def test_python_stop_hook(self):
|
|
"""Test that you can run a python command in a stop-hook when stdin is File based."""
|
|
self.build_and_test("driver.cpp test_stop-hook.cpp", "test_python_stop_hook")
|
|
|
|
@skipIfRemote
|
|
# clang-cl does not support throw or catch (llvm.org/pr24538)
|
|
@skipIfWindows
|
|
@skipIfHostIncompatibleWithTarget
|
|
def test_breakpoint_callback(self):
|
|
"""Test the that SBBreakpoint callback is invoked when a breakpoint is hit."""
|
|
self.build_and_test(
|
|
"driver.cpp test_breakpoint_callback.cpp", "test_breakpoint_callback"
|
|
)
|
|
|
|
@skipIfRemote
|
|
# clang-cl does not support throw or catch (llvm.org/pr24538)
|
|
@skipIfWindows
|
|
@skipIfHostIncompatibleWithTarget
|
|
def test_breakpoint_location_callback(self):
|
|
"""Test the that SBBreakpointLocation callback is invoked when a breakpoint is hit."""
|
|
self.build_and_test(
|
|
"driver.cpp test_breakpoint_location_callback.cpp",
|
|
"test_breakpoint_location_callback",
|
|
)
|
|
|
|
@skipIfRemote
|
|
# clang-cl does not support throw or catch (llvm.org/pr24538)
|
|
@skipIfWindows
|
|
@expectedFlakeyFreeBSD
|
|
@skipIfHostIncompatibleWithTarget
|
|
def test_sb_api_listener_event_description(self):
|
|
"""Test the description of an SBListener breakpoint event is valid."""
|
|
self.build_and_test(
|
|
"driver.cpp listener_test.cpp test_listener_event_description.cpp",
|
|
"test_listener_event_description",
|
|
)
|
|
|
|
@skipIfRemote
|
|
# clang-cl does not support throw or catch (llvm.org/pr24538)
|
|
@skipIfWindows
|
|
@expectedFlakeyFreeBSD
|
|
@skipIfHostIncompatibleWithTarget
|
|
def test_sb_api_listener_event_process_state(self):
|
|
"""Test that a registered SBListener receives events when a process
|
|
changes state.
|
|
"""
|
|
self.build_and_test(
|
|
"driver.cpp listener_test.cpp test_listener_event_process_state.cpp",
|
|
"test_listener_event_process_state",
|
|
)
|
|
|
|
@skipIfRemote
|
|
# clang-cl does not support throw or catch (llvm.org/pr24538)
|
|
@skipIfWindows
|
|
@expectedFlakeyFreeBSD
|
|
@skipIf(oslist=["linux"]) # flakey
|
|
@skipIfHostIncompatibleWithTarget
|
|
def test_sb_api_listener_resume(self):
|
|
"""Test that a process can be resumed from a non-main thread."""
|
|
self.build_and_test(
|
|
"driver.cpp listener_test.cpp test_listener_resume.cpp",
|
|
"test_listener_resume",
|
|
)
|
|
|
|
@skipIfRemote
|
|
# clang-cl does not support throw or catch (llvm.org/pr24538)
|
|
@skipIfWindows
|
|
@skipIfHostIncompatibleWithTarget
|
|
def test_concurrent_unwind(self):
|
|
"""Test that you can run a python command in a stop-hook when stdin is File based."""
|
|
self.build_and_test(
|
|
"driver.cpp test_concurrent_unwind.cpp",
|
|
"test_concurrent_unwind",
|
|
inferior_source="deep_stack.cpp",
|
|
)
|
|
|
|
def build_and_test(self, sources, test_name, inferior_source="inferior.cpp"):
|
|
"""Build LLDB test from sources, and run expecting 0 exit code"""
|
|
|
|
# These tests link against host lldb API.
|
|
# Compiler's target triple must match liblldb triple
|
|
# because remote is disabled, we can assume that the os is the same
|
|
# still need to check architecture
|
|
if self.getLldbArchitecture() != self.getArchitecture():
|
|
self.skipTest(
|
|
"This test is only run if the target arch is the same as the lldb binary arch"
|
|
)
|
|
|
|
self.inferior = "inferior_program"
|
|
self.buildProgram(inferior_source, self.inferior)
|
|
self.addTearDownHook(lambda: os.remove(self.getBuildArtifact(self.inferior)))
|
|
|
|
self.buildDriver(sources, test_name)
|
|
self.addTearDownHook(lambda: os.remove(self.getBuildArtifact(test_name)))
|
|
|
|
test_exe = self.getBuildArtifact(test_name)
|
|
exe = [test_exe, self.getBuildArtifact(self.inferior)]
|
|
|
|
# check_call will raise a CalledProcessError if the executable doesn't
|
|
# return exit code 0 to indicate success. We can let this exception go
|
|
# - the test harness will recognize it as a test failure.
|
|
subprocess.check_call(exe)
|
|
|
|
def build_program(self, sources, program):
|
|
return self.buildDriver(sources, program)
|