[Lldb-commits] [PATCH] D91220: [ThreadPlan] Add a test for `thread step-in -r`, NFC
Vedant Kumar via Phabricator via lldb-commits
lldb-commits at lists.llvm.org
Tue Nov 10 16:10:33 PST 2020
vsk created this revision.
vsk added a reviewer: jingham.
Herald added a project: LLDB.
vsk requested review of this revision.
Herald added a subscriber: JDevlieghere.
Adds test coverage for ThreadPlanStepInRange::SetAvoidRegexp.
See:
http://lab.llvm.org:8080/coverage/coverage-reports/coverage/Users/buildslave/jenkins/workspace/coverage/llvm-project/lldb/source/Target/ThreadPlanStepInRange.cpp.html#L309
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D91220
Files:
lldb/packages/Python/lldbsuite/test/lldbtest.py
lldb/test/API/lang/c/stepping/TestThreadStepInAvoidRegexp.py
lldb/test/API/lang/c/stepping/main.c
Index: lldb/test/API/lang/c/stepping/main.c
===================================================================
--- lldb/test/API/lang/c/stepping/main.c
+++ lldb/test/API/lang/c/stepping/main.c
@@ -39,7 +39,7 @@
{
int A1 = a(1); // frame select 2, thread step-out while stopped at "c(1)"
- int B2 = b(2);
+ int B2 = b(2); // assignment to B2
int A3 = a(3); // frame select 1, thread step-out while stopped at "c(3)"
Index: lldb/test/API/lang/c/stepping/TestThreadStepInAvoidRegexp.py
===================================================================
--- /dev/null
+++ lldb/test/API/lang/c/stepping/TestThreadStepInAvoidRegexp.py
@@ -0,0 +1,52 @@
+"""
+Test thread step-in [ -r | --step-over-regexp ].
+"""
+
+
+
+import lldb
+import lldbsuite.test.lldbutil as lldbutil
+from lldbsuite.test.lldbtest import *
+import lldbsuite.test.lldbutil as lldbutil
+
+
+class ThreadStepInAvoidRegexTestCase(TestBase):
+
+ mydir = TestBase.compute_mydir(__file__)
+
+ def setUp(self):
+ TestBase.setUp(self)
+ self.line1 = line_number(
+ 'main.c', '// frame select 2, thread step-out while stopped at "c(1)"')
+ self.line2 = line_number(
+ 'main.c', '// assignment to B2')
+
+ def test_step_out_avoid_regexp(self):
+ """Exercise thread step-in -r"""
+ self.build()
+ exe = self.getBuildArtifact("a.out")
+ self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
+
+ # Create a breakpoint inside function 'c'.
+ lldbutil.run_break_set_by_file_and_line(
+ self, "main.c", self.line1, num_expected_locations=1)
+
+ # Now run the program.
+ self.runCmd("run", RUN_SUCCEEDED)
+
+ # The process should be stopped at this point.
+ self.expect("process status", PROCESS_STOPPED,
+ patterns=['Process .* stopped'])
+
+ # The frame #0 should correspond to main.c:40, the first line of main.
+ self.expect("thread backtrace", STOPPED_DUE_TO_BREAKPOINT,
+ substrs=["stop reason = breakpoint"],
+ patterns=["frame #0.*main.c:%d" % self.line1])
+
+ # Now step in, skipping the frames for 'b' and 'a'.
+ self.runCmd("thread step-in -r 'a'")
+
+ # We should be at the assignment to B2.
+ self.expect("thread backtrace", STEP_IN_SUCCEEDED,
+ substrs=["stop reason = step in"],
+ patterns=["frame #0.*main.c:%d" % self.line2])
Index: lldb/packages/Python/lldbsuite/test/lldbtest.py
===================================================================
--- lldb/packages/Python/lldbsuite/test/lldbtest.py
+++ lldb/packages/Python/lldbsuite/test/lldbtest.py
@@ -126,6 +126,8 @@
SOURCE_DISPLAYED_CORRECTLY = "Source code displayed correctly"
+STEP_IN_SUCCEEDED = "Thread step-in succeeded"
+
STEP_OUT_SUCCEEDED = "Thread step-out succeeded"
STOPPED_DUE_TO_EXC_BAD_ACCESS = "Process should be stopped due to bad access exception"
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D91220.304349.patch
Type: text/x-patch
Size: 2991 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20201111/c51697cb/attachment.bin>
More information about the lldb-commits
mailing list