199451b44SJordan Rupprecht""" 299451b44SJordan RupprechtTest lldb Python commands. 399451b44SJordan Rupprecht""" 499451b44SJordan Rupprecht 599451b44SJordan Rupprecht 699451b44SJordan Rupprechtimport sys 799451b44SJordan Rupprechtimport lldb 899451b44SJordan Rupprechtfrom lldbsuite.test.decorators import * 999451b44SJordan Rupprechtfrom lldbsuite.test.lldbtest import * 1099451b44SJordan Rupprecht 1199451b44SJordan Rupprecht 1299451b44SJordan Rupprechtclass CmdPythonTestCase(TestBase): 1399451b44SJordan Rupprecht 1499451b44SJordan Rupprecht mydir = TestBase.compute_mydir(__file__) 1599451b44SJordan Rupprecht NO_DEBUG_INFO_TESTCASE = True 1699451b44SJordan Rupprecht 1799451b44SJordan Rupprecht def test(self): 1899451b44SJordan Rupprecht self.build() 1999451b44SJordan Rupprecht self.pycmd_tests() 2099451b44SJordan Rupprecht 2199451b44SJordan Rupprecht def pycmd_tests(self): 2299451b44SJordan Rupprecht self.runCmd("command source py_import") 2399451b44SJordan Rupprecht 2499451b44SJordan Rupprecht # Test a bunch of different kinds of python callables with 2599451b44SJordan Rupprecht # both 4 and 5 positional arguments. 2699451b44SJordan Rupprecht self.expect("foobar", substrs=["All good"]) 2799451b44SJordan Rupprecht self.expect("foobar4", substrs=["All good"]) 2899451b44SJordan Rupprecht self.expect("vfoobar", substrs=["All good"]) 2999451b44SJordan Rupprecht self.expect("v5foobar", substrs=["All good"]) 3099451b44SJordan Rupprecht self.expect("sfoobar", substrs=["All good"]) 3199451b44SJordan Rupprecht self.expect("cfoobar", substrs=["All good"]) 3299451b44SJordan Rupprecht self.expect("ifoobar", substrs=["All good"]) 3399451b44SJordan Rupprecht self.expect("sfoobar4", substrs=["All good"]) 3499451b44SJordan Rupprecht self.expect("cfoobar4", substrs=["All good"]) 3599451b44SJordan Rupprecht self.expect("ifoobar4", substrs=["All good"]) 3699451b44SJordan Rupprecht self.expect("ofoobar", substrs=["All good"]) 3799451b44SJordan Rupprecht self.expect("ofoobar4", substrs=["All good"]) 3899451b44SJordan Rupprecht 3999451b44SJordan Rupprecht # Verify command that specifies eCommandRequiresTarget returns failure 4099451b44SJordan Rupprecht # without a target. 4199451b44SJordan Rupprecht self.expect('targetname', 4299451b44SJordan Rupprecht substrs=['a.out'], matching=False, error=True) 4399451b44SJordan Rupprecht 4499451b44SJordan Rupprecht exe = self.getBuildArtifact("a.out") 4599451b44SJordan Rupprecht self.expect("file " + exe, 4699451b44SJordan Rupprecht patterns=["Current executable set to .*a.out"]) 4799451b44SJordan Rupprecht 4899451b44SJordan Rupprecht self.expect('targetname', 4999451b44SJordan Rupprecht substrs=['a.out'], matching=True, error=False) 5099451b44SJordan Rupprecht 5199451b44SJordan Rupprecht # This is the function to remove the custom commands in order to have a 5299451b44SJordan Rupprecht # clean slate for the next test case. 5399451b44SJordan Rupprecht def cleanup(): 5499451b44SJordan Rupprecht self.runCmd('command script delete welcome', check=False) 5599451b44SJordan Rupprecht self.runCmd('command script delete targetname', check=False) 5699451b44SJordan Rupprecht self.runCmd('command script delete longwait', check=False) 5799451b44SJordan Rupprecht self.runCmd('command script delete mysto', check=False) 5899451b44SJordan Rupprecht self.runCmd('command script delete tell_sync', check=False) 5999451b44SJordan Rupprecht self.runCmd('command script delete tell_async', check=False) 6099451b44SJordan Rupprecht self.runCmd('command script delete tell_curr', check=False) 6199451b44SJordan Rupprecht self.runCmd('command script delete bug11569', check=False) 6299451b44SJordan Rupprecht self.runCmd('command script delete takes_exe_ctx', check=False) 6399451b44SJordan Rupprecht self.runCmd('command script delete decorated', check=False) 6499451b44SJordan Rupprecht 6599451b44SJordan Rupprecht # Execute the cleanup function during test case tear down. 6699451b44SJordan Rupprecht self.addTearDownHook(cleanup) 6799451b44SJordan Rupprecht 6899451b44SJordan Rupprecht # Interact with debugger in synchronous mode 6999451b44SJordan Rupprecht self.setAsync(False) 7099451b44SJordan Rupprecht 7199451b44SJordan Rupprecht # We don't want to display the stdout if not in TraceOn() mode. 7299451b44SJordan Rupprecht if not self.TraceOn(): 7399451b44SJordan Rupprecht self.HideStdout() 7499451b44SJordan Rupprecht 7599451b44SJordan Rupprecht self.expect('welcome Enrico', 7699451b44SJordan Rupprecht substrs=['Hello Enrico, welcome to LLDB']) 7799451b44SJordan Rupprecht 7899451b44SJordan Rupprecht self.expect("help welcome", 7999451b44SJordan Rupprecht substrs=['Just a docstring for welcome_impl', 8099451b44SJordan Rupprecht 'A command that says hello to LLDB users']) 8199451b44SJordan Rupprecht 8299451b44SJordan Rupprecht decorated_commands = ["decorated" + str(n) for n in range(1, 5)] 8399451b44SJordan Rupprecht for name in decorated_commands: 8499451b44SJordan Rupprecht self.expect(name, substrs=["hello from " + name]) 8599451b44SJordan Rupprecht self.expect("help " + name, 8699451b44SJordan Rupprecht substrs=["Python command defined by @lldb.command"]) 8799451b44SJordan Rupprecht 8899451b44SJordan Rupprecht self.expect("help", 8999451b44SJordan Rupprecht substrs=['For more information run'] 9099451b44SJordan Rupprecht + decorated_commands + ['welcome']) 9199451b44SJordan Rupprecht 9299451b44SJordan Rupprecht self.expect("help -a", 9399451b44SJordan Rupprecht substrs=['For more information run'] 9499451b44SJordan Rupprecht + decorated_commands + ['welcome']) 9599451b44SJordan Rupprecht 9699451b44SJordan Rupprecht self.expect("help -u", matching=False, 9799451b44SJordan Rupprecht substrs=['For more information run']) 9899451b44SJordan Rupprecht 9999451b44SJordan Rupprecht self.runCmd("command script delete welcome") 10099451b44SJordan Rupprecht 10199451b44SJordan Rupprecht self.expect('welcome Enrico', matching=False, error=True, 10299451b44SJordan Rupprecht substrs=['Hello Enrico, welcome to LLDB']) 10399451b44SJordan Rupprecht 10499451b44SJordan Rupprecht self.expect('targetname fail', error=True, 10599451b44SJordan Rupprecht substrs=['a test for error in command']) 10699451b44SJordan Rupprecht 10799451b44SJordan Rupprecht self.expect('command script list', 10899451b44SJordan Rupprecht substrs=['targetname', 10999451b44SJordan Rupprecht 'For more information run']) 11099451b44SJordan Rupprecht 11199451b44SJordan Rupprecht self.expect("help targetname", 11299451b44SJordan Rupprecht substrs=['Expects', '\'raw\'', 'input', 11399451b44SJordan Rupprecht 'help', 'raw-input']) 11499451b44SJordan Rupprecht 11599451b44SJordan Rupprecht self.expect("longwait", 11699451b44SJordan Rupprecht substrs=['Done; if you saw the delays I am doing OK']) 11799451b44SJordan Rupprecht 11899451b44SJordan Rupprecht self.runCmd("b main") 11999451b44SJordan Rupprecht self.runCmd("run") 12099451b44SJordan Rupprecht self.runCmd("mysto 3") 12199451b44SJordan Rupprecht self.expect("frame variable array", 12299451b44SJordan Rupprecht substrs=['[0] = 79630', '[1] = 388785018', '[2] = 0']) 12399451b44SJordan Rupprecht self.runCmd("mysto 3") 12499451b44SJordan Rupprecht self.expect("frame variable array", 12599451b44SJordan Rupprecht substrs=['[0] = 79630', '[4] = 388785018', '[5] = 0']) 12699451b44SJordan Rupprecht 12799451b44SJordan Rupprecht# we cannot use the stepover command to check for async execution mode since LLDB 12899451b44SJordan Rupprecht# seems to get confused when events start to queue up 12999451b44SJordan Rupprecht self.expect("tell_sync", 13099451b44SJordan Rupprecht substrs=['running sync']) 13199451b44SJordan Rupprecht self.expect("tell_async", 13299451b44SJordan Rupprecht substrs=['running async']) 13399451b44SJordan Rupprecht self.expect("tell_curr", 13499451b44SJordan Rupprecht substrs=['I am running sync']) 13599451b44SJordan Rupprecht 13699451b44SJordan Rupprecht# check that the execution context is passed in to commands that ask for it 13799451b44SJordan Rupprecht self.expect("takes_exe_ctx", substrs=["a.out"]) 13899451b44SJordan Rupprecht 13999451b44SJordan Rupprecht # Test that a python command can redefine itself 14099451b44SJordan Rupprecht self.expect('command script add -f foobar welcome -h "just some help"') 14199451b44SJordan Rupprecht 14299451b44SJordan Rupprecht self.runCmd("command script clear") 14399451b44SJordan Rupprecht 14499451b44SJordan Rupprecht # Test that re-defining an existing command works 14599451b44SJordan Rupprecht self.runCmd( 14699451b44SJordan Rupprecht 'command script add my_command --class welcome.WelcomeCommand') 14799451b44SJordan Rupprecht self.expect('my_command Blah', substrs=['Hello Blah, welcome to LLDB']) 14899451b44SJordan Rupprecht 14999451b44SJordan Rupprecht self.runCmd( 150*c5011aedSJim Ingham 'command script add my_command -o --class welcome.TargetnameCommand') 15199451b44SJordan Rupprecht self.expect('my_command', substrs=['a.out']) 15299451b44SJordan Rupprecht 15399451b44SJordan Rupprecht self.runCmd("command script clear") 15499451b44SJordan Rupprecht 15599451b44SJordan Rupprecht self.expect('command script list', matching=False, 15699451b44SJordan Rupprecht substrs=['targetname', 15799451b44SJordan Rupprecht 'longwait']) 15899451b44SJordan Rupprecht 15999451b44SJordan Rupprecht self.expect('command script add -f foobar frame', error=True, 16099451b44SJordan Rupprecht substrs=['cannot add command']) 16199451b44SJordan Rupprecht 16299451b44SJordan Rupprecht # http://llvm.org/bugs/show_bug.cgi?id=11569 16399451b44SJordan Rupprecht # LLDBSwigPythonCallCommand crashes when a command script returns an 16499451b44SJordan Rupprecht # object 16599451b44SJordan Rupprecht self.runCmd('command script add -f bug11569 bug11569') 16699451b44SJordan Rupprecht # This should not crash. 16799451b44SJordan Rupprecht self.runCmd('bug11569', check=False) 168