""" Test lldb data formatter subsystem. """ import lldb from lldbsuite.test.decorators import * from lldbsuite.test.lldbbench import * from lldbsuite.test.lldbtest import * from lldbsuite.test import lldbutil class TestBenchmarkContinue(BenchBase): @benchmarks_test def test_run_command(self): """Benchmark different ways to continue a process""" self.build() self.data_formatter_commands() def setUp(self): # Call super's setUp(). BenchBase.setUp(self) def data_formatter_commands(self): """Benchmark different ways to continue a process""" self.runCmd("file " + self.getBuildArtifact("a.out"), CURRENT_EXECUTABLE_SET) bkpt = self.target().FindBreakpointByID( lldbutil.run_break_set_by_source_regexp(self, "// break here") ) self.runCmd("run", RUN_SUCCEEDED) # The stop reason of the thread should be breakpoint. self.expect( "thread list", STOPPED_DUE_TO_BREAKPOINT, substrs=["stopped", "stop reason = breakpoint"], ) # This is the function to remove the custom formats in order to have a # clean slate for the next test case. def cleanup(): self.runCmd("type format clear", check=False) self.runCmd("type summary clear", check=False) self.runCmd("type filter clear", check=False) self.runCmd("type synth clear", check=False) self.runCmd("settings set target.max-children-count 256", check=False) # Execute the cleanup function during test case tear down. self.addTearDownHook(cleanup) runCmd_sw = Stopwatch() lldbutil_sw = Stopwatch() for i in range(0, 15): runCmd_sw.start() self.runCmd("continue") runCmd_sw.stop() for i in range(0, 15): lldbutil_sw.start() lldbutil.continue_to_breakpoint(self.process(), bkpt) lldbutil_sw.stop() print("runCmd: %s\nlldbutil: %s" % (runCmd_sw, lldbutil_sw))