diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2016-01-06 20:12:03 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2016-01-06 20:12:03 +0000 | 
| commit | 9e6d35490a6542f9c97607f93c2ef8ca8e03cbcc (patch) | |
| tree | dd2a1ddf0476664c2b823409c36cbccd52662ca7 /packages/Python/lldbsuite/test/api/multithreaded/TestMultithreaded.py | |
| parent | 3bd2e91faeb9eeec1aae82c64a3253afff551cfd (diff) | |
Notes
Diffstat (limited to 'packages/Python/lldbsuite/test/api/multithreaded/TestMultithreaded.py')
| -rw-r--r-- | packages/Python/lldbsuite/test/api/multithreaded/TestMultithreaded.py | 91 | 
1 files changed, 91 insertions, 0 deletions
| diff --git a/packages/Python/lldbsuite/test/api/multithreaded/TestMultithreaded.py b/packages/Python/lldbsuite/test/api/multithreaded/TestMultithreaded.py new file mode 100644 index 000000000000..0b405091ebd1 --- /dev/null +++ b/packages/Python/lldbsuite/test/api/multithreaded/TestMultithreaded.py @@ -0,0 +1,91 @@ +"""Test the lldb public C++ api breakpoint callbacks.""" + +from __future__ import print_function + +# __package__ = "lldbsuite.test" + + +import os, re +from lldbsuite.test.lldbtest import * +import lldbsuite.test.lldbutil as lldbutil +import subprocess + +class SBBreakpointCallbackCase(TestBase): + +    mydir = TestBase.compute_mydir(__file__) + +    @skipIfRemote +    @skipIfNoSBHeaders +    @skipIfWindows # clang-cl does not support throw or catch (llvm.org/pr24538) +    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 +    @skipIfNoSBHeaders +    @skipIfWindows # clang-cl does not support throw or catch (llvm.org/pr24538) +    @expectedFlakeyFreeBSD +    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') +        pass + +    @skipIfRemote +    @skipIfNoSBHeaders +    @skipIfWindows # clang-cl does not support throw or catch (llvm.org/pr24538) +    @expectedFlakeyFreeBSD +    @expectedFlakeyLinux # Driver occasionally returns '1' as exit status +    @expectedFailureAll("llvm.org/pr23139", oslist=["linux"], compiler="gcc", compiler_version=[">=","4.9"], archs=["x86_64"]) +    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') +        pass + + +    @skipIfRemote +    @skipIfNoSBHeaders +    @skipIfWindows # clang-cl does not support throw or catch (llvm.org/pr24538) +    @expectedFlakeyFreeBSD +    @expectedFlakeyLinux +    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') +        pass + +    def build_and_test(self, sources, test_name, args = None): +        """ 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.cpp', self.inferior) +        self.addTearDownHook(lambda: os.remove(self.inferior)) + +        self.buildDriver(sources, test_name) +        self.addTearDownHook(lambda: os.remove(test_name)) + +        test_exe = os.path.join(os.getcwd(), test_name) +        self.signBinary(test_exe) +        exe = [test_exe, self.inferior] + +        env = {self.dylibPath : self.getLLDBLibraryEnvVal()} +        if self.TraceOn(): +            print("Running test %s" % " ".join(exe)) +            check_call(exe, env=env) +        else: +            with open(os.devnull, 'w') as fnull: +                check_call(exe, env=env, stdout=fnull, stderr=fnull) + +    def build_program(self, sources, program): +        return self.buildDriver(sources, program) | 
