268 lines
9.5 KiB
Python
268 lines
9.5 KiB
Python
|
"""
|
||
|
Test user added container commands
|
||
|
"""
|
||
|
|
||
|
|
||
|
import sys
|
||
|
import lldb
|
||
|
from lldbsuite.test.decorators import *
|
||
|
from lldbsuite.test.lldbtest import *
|
||
|
|
||
|
|
||
|
class TestCmdContainer(TestBase):
|
||
|
NO_DEBUG_INFO_TESTCASE = True
|
||
|
|
||
|
def test_container_add(self):
|
||
|
self.container_add()
|
||
|
|
||
|
def check_command_tree_exists(self):
|
||
|
"""This makes sure we can still run the command tree we added."""
|
||
|
self.runCmd("test-multi")
|
||
|
self.runCmd("test-multi test-multi-sub")
|
||
|
self.runCmd("test-multi test-multi-sub welcome")
|
||
|
|
||
|
def container_add(self):
|
||
|
# Make sure we can't overwrite built-in commands:
|
||
|
self.expect(
|
||
|
"command container add process",
|
||
|
"Can't replace builtin container command",
|
||
|
substrs=["can't replace builtin command"],
|
||
|
error=True,
|
||
|
)
|
||
|
self.expect(
|
||
|
"command container add process non_such_subcommand",
|
||
|
"Can't add to built-in subcommand",
|
||
|
substrs=["Path component: 'process' is not a user command"],
|
||
|
error=True,
|
||
|
)
|
||
|
self.expect(
|
||
|
"command container add process launch",
|
||
|
"Can't replace builtin subcommand",
|
||
|
substrs=["Path component: 'process' is not a user command"],
|
||
|
error=True,
|
||
|
)
|
||
|
|
||
|
# Now lets make a container command:
|
||
|
self.runCmd("command container add -h 'A test container command' test-multi")
|
||
|
# Make sure the help works:
|
||
|
self.expect(
|
||
|
"help test-multi",
|
||
|
"Help works for top-level multi",
|
||
|
substrs=["A test container command"],
|
||
|
)
|
||
|
# Add a subcommand:
|
||
|
self.runCmd(
|
||
|
"command container add -h 'A test container sub-command' test-multi test-multi-sub"
|
||
|
)
|
||
|
# Make sure the help works:
|
||
|
self.expect(
|
||
|
"help test-multi",
|
||
|
"Help shows sub-multi",
|
||
|
substrs=[
|
||
|
"A test container command",
|
||
|
"test-multi-sub -- A test container sub-command",
|
||
|
],
|
||
|
)
|
||
|
self.expect(
|
||
|
"help test-multi test-multi-sub",
|
||
|
"Help shows sub-multi",
|
||
|
substrs=["A test container sub-command"],
|
||
|
)
|
||
|
|
||
|
# Now add a script based command to the container command:
|
||
|
self.runCmd("command script import welcome.py")
|
||
|
self.runCmd(
|
||
|
"command script add -c welcome.WelcomeCommand test-multi test-multi-sub welcome"
|
||
|
)
|
||
|
# Make sure the help still works:
|
||
|
self.expect(
|
||
|
"help test-multi test-multi-sub",
|
||
|
"Listing subcommands works",
|
||
|
substrs=[
|
||
|
"A test container sub-command",
|
||
|
"welcome -- Just a docstring for Welcome",
|
||
|
],
|
||
|
)
|
||
|
self.expect(
|
||
|
"help test-multi test-multi-sub welcome",
|
||
|
"Subcommand help works",
|
||
|
substrs=["Just a docstring for Welcome"],
|
||
|
)
|
||
|
# And make sure it actually works:
|
||
|
self.expect(
|
||
|
"test-multi test-multi-sub welcome friend",
|
||
|
"Test command works",
|
||
|
substrs=["Hello friend, welcome to LLDB"],
|
||
|
)
|
||
|
|
||
|
# Make sure we can make an alias to this:
|
||
|
self.runCmd(
|
||
|
"command alias my-welcome test-multi test-multi-sub welcome",
|
||
|
"We can make an alias to multi-word",
|
||
|
)
|
||
|
self.expect(
|
||
|
"my-welcome friend",
|
||
|
"Test command works",
|
||
|
substrs=["Hello friend, welcome to LLDB"],
|
||
|
)
|
||
|
self.runCmd("command unalias my-welcome")
|
||
|
|
||
|
# Make sure overwriting works on the leaf command. First using the
|
||
|
# explicit option so we should not be able to remove extant commands by default:
|
||
|
|
||
|
self.expect(
|
||
|
"command script add -c welcome.WelcomeCommand2 test-multi test-multi-sub welcome",
|
||
|
"overwrite command w/o -o",
|
||
|
substrs=["cannot add command: sub-command already exists"],
|
||
|
error=True,
|
||
|
)
|
||
|
# But we can with the -o option:
|
||
|
self.runCmd(
|
||
|
"command script add -c welcome.WelcomeCommand2 -o test-multi test-multi-sub welcome"
|
||
|
)
|
||
|
# Make sure we really did overwrite:
|
||
|
self.expect(
|
||
|
"test-multi test-multi-sub welcome friend",
|
||
|
"Used the new command class",
|
||
|
substrs=["Hello friend, welcome again to LLDB"],
|
||
|
)
|
||
|
self.expect(
|
||
|
"apropos welcome",
|
||
|
"welcome should show up in apropos",
|
||
|
substrs=["A docstring for the second Welcome"],
|
||
|
)
|
||
|
self.expect(
|
||
|
"help test-multi test-multi-sub welcome",
|
||
|
"welcome should show up in help",
|
||
|
substrs=["A docstring for the second Welcome"],
|
||
|
)
|
||
|
self.expect("help", "test-multi should show up in help", substrs=["test-multi"])
|
||
|
|
||
|
# Now switch the default and make sure we can now delete w/o the overwrite option:
|
||
|
self.runCmd("settings set interpreter.require-overwrite 0")
|
||
|
self.runCmd(
|
||
|
"command script add -c welcome.WelcomeCommand test-multi test-multi-sub welcome"
|
||
|
)
|
||
|
# Make sure we really did overwrite:
|
||
|
self.expect(
|
||
|
"test-multi test-multi-sub welcome friend",
|
||
|
"Used the new command class",
|
||
|
substrs=["Hello friend, welcome to LLDB"],
|
||
|
)
|
||
|
|
||
|
# Make sure we give good errors when the input is wrong:
|
||
|
self.expect(
|
||
|
"command script delete test-mult test-multi-sub welcome",
|
||
|
"Delete script command - wrong first path component",
|
||
|
substrs=["'test-mult' not found"],
|
||
|
error=True,
|
||
|
)
|
||
|
|
||
|
self.expect(
|
||
|
"command script delete test-multi test-multi-su welcome",
|
||
|
"Delete script command - wrong second path component",
|
||
|
substrs=["'test-multi-su' not found"],
|
||
|
error=True,
|
||
|
)
|
||
|
self.check_command_tree_exists()
|
||
|
|
||
|
self.expect(
|
||
|
"command script delete test-multi test-multi-sub welcom",
|
||
|
"Delete script command - wrong leaf component",
|
||
|
substrs=["'welcom' not found"],
|
||
|
error=True,
|
||
|
)
|
||
|
self.check_command_tree_exists()
|
||
|
|
||
|
self.expect(
|
||
|
"command script delete test-multi test-multi-sub",
|
||
|
"Delete script command - no leaf component",
|
||
|
substrs=["subcommand 'test-multi-sub' is not a user command"],
|
||
|
error=True,
|
||
|
)
|
||
|
self.check_command_tree_exists()
|
||
|
|
||
|
# You can't use command script delete to delete container commands:
|
||
|
self.expect(
|
||
|
"command script delete test-multi",
|
||
|
"Delete script - can't delete container",
|
||
|
substrs=["command 'test-multi' is a multi-word command."],
|
||
|
error=True,
|
||
|
)
|
||
|
self.expect(
|
||
|
"command script delete test-multi test-multi-sub",
|
||
|
"Delete script - can't delete container",
|
||
|
substrs=["subcommand 'test-multi-sub' is not a user command"],
|
||
|
error=True,
|
||
|
)
|
||
|
|
||
|
# You can't use command container delete to delete scripted commands:
|
||
|
self.expect(
|
||
|
"command container delete test-multi test-multi-sub welcome",
|
||
|
"command container can't delete user commands",
|
||
|
substrs=["subcommand 'welcome' is not a container command"],
|
||
|
error=True,
|
||
|
)
|
||
|
|
||
|
# Also make sure you can't alias on top of container commands:
|
||
|
self.expect(
|
||
|
"command alias test-multi process launch",
|
||
|
"Tried to alias on top of a container command",
|
||
|
substrs=[
|
||
|
"'test-multi' is a user container command and cannot be overwritten."
|
||
|
],
|
||
|
error=True,
|
||
|
)
|
||
|
self.check_command_tree_exists()
|
||
|
|
||
|
# Also assert that we can't delete builtin commands:
|
||
|
self.expect(
|
||
|
"command script delete process launch",
|
||
|
"Delete builtin command fails",
|
||
|
substrs=["command 'process' is not a user command"],
|
||
|
error=True,
|
||
|
)
|
||
|
# Now let's do the version that works
|
||
|
self.expect(
|
||
|
"command script delete test-multi test-multi-sub welcome",
|
||
|
"Delete script command by path",
|
||
|
substrs=["Deleted command: test-multi test-multi-sub welcome"],
|
||
|
)
|
||
|
|
||
|
# Now overwrite the sub-command, it should end up empty:
|
||
|
self.runCmd(
|
||
|
"command container add -h 'A different help string' -o test-multi test-multi-sub"
|
||
|
)
|
||
|
# welcome should be gone:
|
||
|
self.expect(
|
||
|
"test-multi test-multi-sub welcome friend",
|
||
|
"did remove subcommand",
|
||
|
substrs=["'test-multi-sub' does not have any subcommands."],
|
||
|
error=True,
|
||
|
)
|
||
|
# We should have the new help:
|
||
|
self.expect(
|
||
|
"help test-multi test-multi-sub",
|
||
|
"help changed",
|
||
|
substrs=["A different help string"],
|
||
|
)
|
||
|
|
||
|
# Now try deleting commands.
|
||
|
self.runCmd("command container delete test-multi test-multi-sub")
|
||
|
self.expect(
|
||
|
"test-multi test-multi-sub",
|
||
|
"Command is not active",
|
||
|
error=True,
|
||
|
substrs=["'test-multi' does not have any subcommands"],
|
||
|
)
|
||
|
self.expect("help test-multi", matching=False, substrs=["test-multi-sub"])
|
||
|
|
||
|
# Next the root command:
|
||
|
self.runCmd("command container delete test-multi")
|
||
|
self.expect(
|
||
|
"test-multi",
|
||
|
"Root command gone",
|
||
|
substrs=["'test-multi' is not a valid command."],
|
||
|
error=True,
|
||
|
)
|