Files
clang-p2996/lldb/test/API/commands/platform/basic/TestPlatformCommand.py
Med Ismail Bennani addb5148f5 [lldb/Target] Add custom interpreter option to platform shell
This patch adds the ability to use a custom interpreter with the
`platform shell` command. If the user set the `-s|--shell` option
with the path to a binary, lldb passes it down to the platform's
`RunShellProcess` method and set it as the shell to use in
`ProcessLaunchInfo to run commands.

Note that not all the Platforms support running shell commands with
custom interpreters (i.e. RemoteGDBServer is only expected to use the
default shell).

This patch also makes some refactoring and cleanups, like swapping
CString for StringRef when possible and updating `SBPlatformShellCommand`
with new methods and a new constructor.

rdar://67759256

Differential Revision: https://reviews.llvm.org/D86667

Signed-off-by: Med Ismail Bennani <medismail.bennani@gmail.com>
2020-09-02 16:36:10 +02:00

104 lines
3.5 KiB
Python

"""
Test some lldb platform commands.
"""
import lldb
from lldbsuite.test.decorators import *
from lldbsuite.test.lldbtest import *
from lldbsuite.test import lldbutil
class PlatformCommandTestCase(TestBase):
mydir = TestBase.compute_mydir(__file__)
NO_DEBUG_INFO_TESTCASE = True
@no_debug_info_test
def test_help_platform(self):
self.runCmd("help platform")
@no_debug_info_test
def test_help_platform(self):
self.expect("help shell", substrs=["Run a shell command on the host.",
"shell <shell-command>"])
@no_debug_info_test
def test_list(self):
self.expect("platform list",
patterns=['^Available platforms:'])
@no_debug_info_test
def test_process_list(self):
self.expect("platform process list",
substrs=['PID', 'TRIPLE', 'NAME'])
@no_debug_info_test
def test_process_info_with_no_arg(self):
"""This is expected to fail and to return a proper error message."""
self.expect("platform process info", error=True,
substrs=['one or more process id(s) must be specified'])
@no_debug_info_test
def test_status(self):
self.expect(
"platform status",
substrs=[
'Platform',
'Triple',
'OS Version',
'Hostname',
'Kernel',
])
@expectedFailureAll(oslist=["windows"])
@no_debug_info_test
def test_shell(self):
""" Test that the platform shell command can invoke ls. """
triple = self.dbg.GetSelectedPlatform().GetTriple()
if re.match(".*-.*-windows", triple):
self.expect(
"platform shell dir c:\\", substrs=[
"Windows", "Program Files"])
self.expect("shell dir c:\\", substrs=["Windows", "Program Files"])
elif re.match(".*-.*-.*-android", triple):
self.expect(
"platform shell ls /",
substrs=[
"cache",
"dev",
"system"])
self.expect("shell ls /",
substrs=["cache", "dev", "system"])
else:
self.expect("platform shell ls /", substrs=["dev", "tmp", "usr"])
self.expect("shell ls /", substrs=["dev", "tmp", "usr"])
@no_debug_info_test
def test_shell_builtin(self):
""" Test a shell built-in command (echo) """
self.expect("platform shell echo hello lldb",
substrs=["hello lldb"])
self.expect("shell echo hello lldb",
substrs=["hello lldb"])
@no_debug_info_test
def test_shell_timeout(self):
""" Test a shell built-in command (sleep) that times out """
self.skipTest("Alias with option not supported by the command interpreter.")
self.expect("platform shell -t 1 -- sleep 15", error=True, substrs=[
"error: timed out waiting for shell command to complete"])
self.expect("shell -t 1 -- sleep 3", error=True, substrs=[
"error: timed out waiting for shell command to complete"])
@no_debug_info_test
def test_host_shell_interpreter(self):
""" Test the host platform shell with a different interpreter """
self.build()
exe = self.getBuildArtifact('a.out')
self.expect("platform shell -h -s " + exe + " -- 'echo $0'",
substrs=['SUCCESS', 'a.out'])