[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