mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 23:26:05 +00:00

Instead of directly annotating pexpect-based tests with `@skipIfWindows`, we can tag them with a new `pexpect` category. We still automatically skip windows behavior by adding `pexpect` to the skip category list if the platform is windows, but also allow non-Windows users to skip them by configuring cmake with `-DLLDB_TEST_USER_ARGS=--skip-category=pexpect` As a prerequisite, remove the restriction that `@add_test_categories` can only apply to test cases, and we make the test runner look for categories on both the class and the test method.
70 lines
2.0 KiB
Python
70 lines
2.0 KiB
Python
"""Test lldb's stepping speed."""
|
|
|
|
import sys
|
|
import lldb
|
|
from lldbsuite.test import configuration
|
|
from lldbsuite.test import lldbtest_config
|
|
from lldbsuite.test.lldbbench import *
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
class SteppingSpeedBench(BenchBase):
|
|
def setUp(self):
|
|
BenchBase.setUp(self)
|
|
self.exe = lldbtest_config.lldbExec
|
|
self.break_spec = "-n main"
|
|
self.count = 50
|
|
|
|
self.trace("self.exe=%s" % self.exe)
|
|
self.trace("self.break_spec=%s" % self.break_spec)
|
|
|
|
@benchmarks_test
|
|
@no_debug_info_test
|
|
@add_test_categories(["pexpect"])
|
|
def test_run_lldb_steppings(self):
|
|
"""Test lldb steppings on a large executable."""
|
|
print()
|
|
self.run_lldb_steppings(self.exe, self.break_spec, self.count)
|
|
print("lldb stepping benchmark:", self.stopwatch)
|
|
|
|
def run_lldb_steppings(self, exe, break_spec, count):
|
|
import pexpect
|
|
|
|
# Set self.child_prompt, which is "(lldb) ".
|
|
self.child_prompt = "(lldb) "
|
|
prompt = self.child_prompt
|
|
|
|
# So that the child gets torn down after the test.
|
|
self.child = pexpect.spawn(
|
|
"%s %s %s" % (lldbtest_config.lldbExec, self.lldbOption, exe)
|
|
)
|
|
child = self.child
|
|
|
|
# Turn on logging for what the child sends back.
|
|
if self.TraceOn():
|
|
child.logfile_read = sys.stdout
|
|
|
|
child.expect_exact(prompt)
|
|
child.sendline("breakpoint set %s" % break_spec)
|
|
child.expect_exact(prompt)
|
|
child.sendline("run")
|
|
child.expect_exact(prompt)
|
|
|
|
# Reset the stopwatch now.
|
|
self.stopwatch.reset()
|
|
for i in range(count):
|
|
with self.stopwatch:
|
|
# Disassemble the function.
|
|
child.sendline("next") # Aka 'thread step-over'.
|
|
child.expect_exact(prompt)
|
|
|
|
child.sendline("quit")
|
|
try:
|
|
self.child.expect(pexpect.EOF)
|
|
except:
|
|
pass
|
|
|
|
self.child = None
|