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