mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-21 12:35:47 -04:00

Summary: A lot of tests do this trick but the vast majority of them don't even call `print()`. Most of this patch was generated by a script that just looks at all the files and deletes the line if there is no `print (` or `print(` anywhere else in the file. I checked the remaining tests manually and deleted the import if we never call print (but instead do stuff like `expr print(...)` and similar false-positives). I also corrected the additional empty lines after the import in the files that I manually edited. Reviewers: JDevlieghere, labath, jfb Reviewed By: labath Subscribers: dexonsmith, wuzish, nemanjai, kbarton, christof, arphaman, abidh, lldb-commits Tags: #lldb Differential Revision: https://reviews.llvm.org/D71452
79 lines
2.8 KiB
Python
79 lines
2.8 KiB
Python
"""
|
|
Test jumping to different places.
|
|
"""
|
|
|
|
|
|
|
|
import lldb
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
class ThreadJumpTestCase(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
def test(self):
|
|
"""Test thread jump handling."""
|
|
self.build(dictionary=self.getBuildFlags())
|
|
exe = self.getBuildArtifact("a.out")
|
|
self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
|
|
|
|
# Find the line numbers for our breakpoints.
|
|
self.mark1 = line_number('main.cpp', '// 1st marker')
|
|
self.mark2 = line_number('main.cpp', '// 2nd marker')
|
|
self.mark3 = line_number('main.cpp', '// 3rd marker')
|
|
self.mark4 = line_number('main.cpp', '// 4th marker')
|
|
self.mark5 = line_number('other.cpp', '// other marker')
|
|
|
|
lldbutil.run_break_set_by_file_and_line(
|
|
self, "main.cpp", self.mark3, num_expected_locations=1)
|
|
self.runCmd("run", RUN_SUCCEEDED)
|
|
|
|
# The stop reason of the thread should be breakpoint 1.
|
|
self.expect(
|
|
"thread list",
|
|
STOPPED_DUE_TO_BREAKPOINT + " 1",
|
|
substrs=[
|
|
'stopped',
|
|
'main.cpp:{}'.format(
|
|
self.mark3),
|
|
'stop reason = breakpoint 1'])
|
|
|
|
# Try the int path, force it to return 'a'
|
|
self.do_min_test(self.mark3, self.mark1, "i", "4")
|
|
# Try the int path, force it to return 'b'
|
|
self.do_min_test(self.mark3, self.mark2, "i", "5")
|
|
# Try the double path, force it to return 'a'
|
|
self.do_min_test(self.mark4, self.mark1, "j", "7")
|
|
# Expected to fail on powerpc64le architecture
|
|
if not self.isPPC64le():
|
|
# Try the double path, force it to return 'b'
|
|
self.do_min_test(self.mark4, self.mark2, "j", "8")
|
|
|
|
# Try jumping to another function in a different file.
|
|
self.runCmd(
|
|
"thread jump --file other.cpp --line %i --force" %
|
|
self.mark5)
|
|
self.expect("process status",
|
|
substrs=["at other.cpp:%i" % self.mark5])
|
|
|
|
# Try jumping to another function (without forcing)
|
|
self.expect(
|
|
"j main.cpp:%i" %
|
|
self.mark1,
|
|
COMMAND_FAILED_AS_EXPECTED,
|
|
error=True,
|
|
substrs=["error"])
|
|
|
|
def do_min_test(self, start, jump, var, value):
|
|
# jump to the start marker
|
|
self.runCmd("j %i" % start)
|
|
self.runCmd("thread step-in") # step into the min fn
|
|
# jump to the branch we're interested in
|
|
self.runCmd("j %i" % jump)
|
|
self.runCmd("thread step-out") # return out
|
|
self.runCmd("thread step-over") # assign to the global
|
|
self.expect("expr %s" % var, substrs=[value]) # check it
|