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