This changes Python API tests to use a single build shared across all test functions, instead of the previous default behavior of a separate build dir for each test function. This build behavior opt-out, tests can use the previous behavior of one individual (unshared) build directory per test function, by setting `SHARED_BUILD_TESTCASE` to False (in the test class). The motivation is to make the test suite more efficient, by not repeatedly building the same test source. When running tests on my macOS machine, this reduces the time of `ninja check-lldb-api` by almost 60% (sample numbers: from ~492s down to ~207s = 58%). Almost 5min time saved. Each test function still calls `self.build()`, but only the first call will do a build, in the subsequent tests `make` will be a no-op because the sources won't have changed.
61 lines
2.2 KiB
Python
61 lines
2.2 KiB
Python
"""Test passing structs to Objective-C methods."""
|
|
|
|
|
|
import lldb
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
class TestObjCStructArgument(TestBase):
|
|
SHARED_BUILD_TESTCASE = False
|
|
|
|
def setUp(self):
|
|
# Call super's setUp().
|
|
TestBase.setUp(self)
|
|
# Find the line numbers to break inside main().
|
|
self.main_source = "test.m"
|
|
self.break_line = line_number(self.main_source, "// Set breakpoint here.")
|
|
|
|
# this test program only builds for ios with -gmodules
|
|
@add_test_categories(["gmodules", "pyapi"])
|
|
@skipIf(oslist=["ios", "watchos", "tvos", "bridgeos"], archs=["armv7", "arm64"])
|
|
def test_with_python_api(self):
|
|
"""Test passing structs to Objective-C methods."""
|
|
self.build()
|
|
exe = self.getBuildArtifact("a.out")
|
|
|
|
target = self.dbg.CreateTarget(exe)
|
|
self.assertTrue(target, VALID_TARGET)
|
|
|
|
bpt = target.BreakpointCreateByLocation(self.main_source, self.break_line)
|
|
self.assertTrue(bpt, VALID_BREAKPOINT)
|
|
|
|
# Now launch the process, and do not stop at entry point.
|
|
process = target.LaunchSimple(None, None, self.get_process_working_directory())
|
|
|
|
self.assertTrue(process, PROCESS_IS_VALID)
|
|
|
|
# The stop reason of the thread should be breakpoint.
|
|
thread_list = lldbutil.get_threads_stopped_at_breakpoint(process, bpt)
|
|
|
|
# Make sure we stopped at the first breakpoint.
|
|
self.assertNotEqual(len(thread_list), 0, "No thread stopped at our breakpoint.")
|
|
self.assertEqual(
|
|
len(thread_list), 1, "More than one thread stopped at our breakpoint."
|
|
)
|
|
|
|
frame = thread_list[0].GetFrameAtIndex(0)
|
|
self.assertTrue(frame, "Got a valid frame 0 frame.")
|
|
|
|
self.expect("expression [summer sumThings:tts]", substrs=["9"])
|
|
|
|
self.expect(
|
|
"po [NSValue valueWithRect:rect]", substrs=["NSRect: {{0, 0}, {10, 20}}"]
|
|
)
|
|
|
|
# Now make sure we can call a method that returns a struct without
|
|
# crashing.
|
|
cmd_value = frame.EvaluateExpression("[provider getRange]")
|
|
self.assertTrue(cmd_value.IsValid())
|