xref: /llvm-project/lldb/test/API/functionalities/step_scripted/TestStepScripted.py (revision 1e566f6b47fb77812d99c93e0a1b8613d288058c)
199451b44SJordan Rupprecht"""
299451b44SJordan RupprechtTests stepping with scripted thread plans.
399451b44SJordan Rupprecht"""
499451b44SJordan Rupprecht
599451b44SJordan Rupprechtimport lldb
699451b44SJordan Rupprechtimport lldbsuite.test.lldbutil as lldbutil
7*1e566f6bSJonas Devliegherefrom lldbsuite.test.decorators import *
899451b44SJordan Rupprechtfrom lldbsuite.test.lldbtest import *
999451b44SJordan Rupprecht
1099451b44SJordan Rupprechtclass StepScriptedTestCase(TestBase):
1199451b44SJordan Rupprecht
1299451b44SJordan Rupprecht    mydir = TestBase.compute_mydir(__file__)
1399451b44SJordan Rupprecht
1499451b44SJordan Rupprecht    NO_DEBUG_INFO_TESTCASE = True
1599451b44SJordan Rupprecht
1699451b44SJordan Rupprecht    def setUp(self):
1799451b44SJordan Rupprecht        TestBase.setUp(self)
1899451b44SJordan Rupprecht        self.main_source_file = lldb.SBFileSpec("main.c")
1999451b44SJordan Rupprecht        self.runCmd("command script import Steps.py")
2099451b44SJordan Rupprecht
21*1e566f6bSJonas Devlieghere    @skipIfReproducer # Unexpected packet during replay
2299451b44SJordan Rupprecht    def test_standard_step_out(self):
2399451b44SJordan Rupprecht        """Tests stepping with the scripted thread plan laying over a standard
2499451b44SJordan Rupprecht        thread plan for stepping out."""
2599451b44SJordan Rupprecht        self.build()
2699451b44SJordan Rupprecht        self.step_out_with_scripted_plan("Steps.StepOut")
2799451b44SJordan Rupprecht
28*1e566f6bSJonas Devlieghere    @skipIfReproducer # Unexpected packet during replay
2999451b44SJordan Rupprecht    def test_scripted_step_out(self):
3099451b44SJordan Rupprecht        """Tests stepping with the scripted thread plan laying over an another
3199451b44SJordan Rupprecht        scripted thread plan for stepping out."""
3299451b44SJordan Rupprecht        self.build()
3399451b44SJordan Rupprecht        self.step_out_with_scripted_plan("Steps.StepScripted")
3499451b44SJordan Rupprecht
3599451b44SJordan Rupprecht    def step_out_with_scripted_plan(self, name):
3699451b44SJordan Rupprecht        (target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(self,
3799451b44SJordan Rupprecht                                                                            "Set a breakpoint here",
3899451b44SJordan Rupprecht                                                                            self.main_source_file)
3999451b44SJordan Rupprecht
4099451b44SJordan Rupprecht        frame = thread.GetFrameAtIndex(0)
4199451b44SJordan Rupprecht        self.assertEqual("foo", frame.GetFunctionName())
4299451b44SJordan Rupprecht
4399451b44SJordan Rupprecht        err = thread.StepUsingScriptedThreadPlan(name)
4499451b44SJordan Rupprecht        self.assertTrue(err.Success(), err.GetCString())
4599451b44SJordan Rupprecht
4699451b44SJordan Rupprecht        frame = thread.GetFrameAtIndex(0)
4799451b44SJordan Rupprecht        self.assertEqual("main", frame.GetFunctionName())
4899451b44SJordan Rupprecht
4999451b44SJordan Rupprecht
5099451b44SJordan Rupprecht    def test_misspelled_plan_name(self):
5199451b44SJordan Rupprecht        """Test that we get a useful error if we misspell the plan class name"""
5299451b44SJordan Rupprecht        self.build()
5399451b44SJordan Rupprecht        (target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(self,
5499451b44SJordan Rupprecht                                                                            "Set a breakpoint here",
5599451b44SJordan Rupprecht                                                                            self.main_source_file)
5699451b44SJordan Rupprecht        stop_id = process.GetStopID()
5799451b44SJordan Rupprecht        # Pass a non-existent class for the plan class:
5899451b44SJordan Rupprecht        err = thread.StepUsingScriptedThreadPlan("NoSuchModule.NoSuchPlan")
5999451b44SJordan Rupprecht
6099451b44SJordan Rupprecht        # Make sure we got a good error:
6199451b44SJordan Rupprecht        self.assertTrue(err.Fail(), "We got a failure state")
6299451b44SJordan Rupprecht        msg = err.GetCString()
6399451b44SJordan Rupprecht        self.assertTrue("NoSuchModule.NoSuchPlan" in msg, "Mentioned missing class")
6499451b44SJordan Rupprecht
6599451b44SJordan Rupprecht        # Make sure we didn't let the process run:
6699451b44SJordan Rupprecht        self.assertEqual(stop_id, process.GetStopID(), "Process didn't run")
6799451b44SJordan Rupprecht
68*1e566f6bSJonas Devlieghere    @skipIfReproducer # Unexpected packet during replay
6999451b44SJordan Rupprecht    def test_checking_variable(self):
7099451b44SJordan Rupprecht        """Test that we can call SBValue API's from a scripted thread plan - using SBAPI's to step"""
7199451b44SJordan Rupprecht        self.do_test_checking_variable(False)
7299451b44SJordan Rupprecht
73*1e566f6bSJonas Devlieghere    @skipIfReproducer # Unexpected packet during replay
7499451b44SJordan Rupprecht    def test_checking_variable_cli(self):
7599451b44SJordan Rupprecht        """Test that we can call SBValue API's from a scripted thread plan - using cli to step"""
7699451b44SJordan Rupprecht        self.do_test_checking_variable(True)
7799451b44SJordan Rupprecht
7899451b44SJordan Rupprecht    def do_test_checking_variable(self, use_cli):
7999451b44SJordan Rupprecht        self.build()
8099451b44SJordan Rupprecht        (target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(self,
8199451b44SJordan Rupprecht                                                                            "Set a breakpoint here",
8299451b44SJordan Rupprecht                                                                            self.main_source_file)
8399451b44SJordan Rupprecht
8499451b44SJordan Rupprecht        frame = thread.GetFrameAtIndex(0)
8599451b44SJordan Rupprecht        self.assertEqual("foo", frame.GetFunctionName())
8699451b44SJordan Rupprecht        foo_val = frame.FindVariable("foo")
8799451b44SJordan Rupprecht        self.assertTrue(foo_val.GetError().Success(), "Got the foo variable")
8899451b44SJordan Rupprecht        self.assertEqual(foo_val.GetValueAsUnsigned(), 10, "foo starts at 10")
8999451b44SJordan Rupprecht
9099451b44SJordan Rupprecht        if use_cli:
9199451b44SJordan Rupprecht            result = lldb.SBCommandReturnObject()
9299451b44SJordan Rupprecht            self.dbg.GetCommandInterpreter().HandleCommand(
9399451b44SJordan Rupprecht                "thread step-scripted -C Steps.StepUntil -k variable_name -v foo",
9499451b44SJordan Rupprecht                result)
9599451b44SJordan Rupprecht            self.assertTrue(result.Succeeded())
9699451b44SJordan Rupprecht        else:
9799451b44SJordan Rupprecht            args_data = lldb.SBStructuredData()
9899451b44SJordan Rupprecht            data = lldb.SBStream()
9999451b44SJordan Rupprecht            data.Print('{"variable_name" : "foo"}')
10099451b44SJordan Rupprecht            error = args_data.SetFromJSON(data)
10199451b44SJordan Rupprecht            self.assertTrue(error.Success(), "Made the args_data correctly")
10299451b44SJordan Rupprecht
10399451b44SJordan Rupprecht            err = thread.StepUsingScriptedThreadPlan("Steps.StepUntil", args_data, True)
10499451b44SJordan Rupprecht            self.assertTrue(err.Success(), err.GetCString())
10599451b44SJordan Rupprecht
10699451b44SJordan Rupprecht        # We should not have exited:
10799451b44SJordan Rupprecht        self.assertEqual(process.GetState(), lldb.eStateStopped, "We are stopped")
10899451b44SJordan Rupprecht
10999451b44SJordan Rupprecht        # We should still be in foo:
11099451b44SJordan Rupprecht        self.assertEqual("foo", frame.GetFunctionName())
11199451b44SJordan Rupprecht
11299451b44SJordan Rupprecht        # And foo should have changed:
11399451b44SJordan Rupprecht        self.assertTrue(foo_val.GetValueDidChange(), "Foo changed")
114