diff options
Diffstat (limited to 'lldb/packages/Python/lldbsuite/test/help/TestHelp.py')
-rw-r--r-- | lldb/packages/Python/lldbsuite/test/help/TestHelp.py | 266 |
1 files changed, 0 insertions, 266 deletions
diff --git a/lldb/packages/Python/lldbsuite/test/help/TestHelp.py b/lldb/packages/Python/lldbsuite/test/help/TestHelp.py deleted file mode 100644 index 55bcbd02be7..00000000000 --- a/lldb/packages/Python/lldbsuite/test/help/TestHelp.py +++ /dev/null @@ -1,266 +0,0 @@ -""" -Test some lldb help commands. - -See also CommandInterpreter::OutputFormattedHelpText(). -""" - -from __future__ import print_function - - -import os -import lldb -from lldbsuite.test.decorators import * -from lldbsuite.test.lldbtest import * -from lldbsuite.test import lldbutil - - -class HelpCommandTestCase(TestBase): - - mydir = TestBase.compute_mydir(__file__) - - @no_debug_info_test - def test_simplehelp(self): - """A simple test of 'help' command and its output.""" - self.expect("help", - startstr='Debugger commands:') - - self.expect("help -a", matching=False, - substrs=['next']) - - self.expect("help", matching=True, - substrs=['next']) - - @no_debug_info_test - def test_help_on_help(self): - """Testing the help on the help facility.""" - self.expect("help help", matching=True, - substrs=['--hide-aliases', - '--hide-user-commands']) - - @no_debug_info_test - def version_number_string(self): - """Helper function to find the version number string of lldb.""" - plist = os.path.join( - os.environ["LLDB_SRC"], - "resources", - "LLDB-Info.plist") - try: - CFBundleVersionSegFound = False - with open(plist, 'r') as f: - for line in f: - if CFBundleVersionSegFound: - version_line = line.strip() - import re - m = re.match("<string>(.*)</string>", version_line) - if m: - version = m.group(1) - return version - else: - # Unsuccessful, let's juts break out of the for - # loop. - break - - if line.find("<key>CFBundleVersion</key>") != -1: - # Found our match. The next line contains our version - # string, for example: - # - # <string>38</string> - CFBundleVersionSegFound = True - - except: - # Just fallthrough... - import traceback - traceback.print_exc() - - # Use None to signify that we are not able to grok the version number. - return None - - @no_debug_info_test - def test_help_arch(self): - """Test 'help arch' which should list of supported architectures.""" - self.expect("help arch", - substrs=['arm', 'x86_64', 'i386']) - - @no_debug_info_test - def test_help_version(self): - """Test 'help version' and 'version' commands.""" - self.expect("help version", - substrs=['Show the LLDB debugger version.']) - import re - version_str = self.version_number_string() - match = re.match('[0-9]+', version_str) - search_regexp = ['lldb( version|-' + (version_str if match else '[0-9]+') + ').*\n'] - - self.expect("version", - patterns=search_regexp) - - @no_debug_info_test - def test_help_should_not_crash_lldb(self): - """Command 'help disasm' should not crash lldb.""" - self.runCmd("help disasm", check=False) - self.runCmd("help unsigned-integer") - - @no_debug_info_test - def test_help_should_not_hang_emacsshell(self): - """Command 'settings set term-width 0' should not hang the help command.""" - self.expect( - "settings set term-width 0", - COMMAND_FAILED_AS_EXPECTED, - error=True, - substrs=['error: 0 is out of range, valid values must be between']) - # self.runCmd("settings set term-width 0") - self.expect("help", - startstr='Debugger commands:') - - @no_debug_info_test - def test_help_breakpoint_set(self): - """Test that 'help breakpoint set' does not print out redundant lines of: - 'breakpoint set [-s <shlib-name>] ...'.""" - self.expect("help breakpoint set", matching=False, - substrs=['breakpoint set [-s <shlib-name>]']) - - @no_debug_info_test - def test_help_image_dump_symtab_should_not_crash(self): - """Command 'help image dump symtab' should not crash lldb.""" - # 'image' is an alias for 'target modules'. - self.expect("help image dump symtab", - substrs=['dump symtab', - 'sort-order']) - - @no_debug_info_test - def test_help_image_du_sym_is_ambiguous(self): - """Command 'help image du sym' is ambiguous and spits out the list of candidates.""" - self.expect("help image du sym", - COMMAND_FAILED_AS_EXPECTED, error=True, - substrs=['error: ambiguous command image du sym', - 'symfile', - 'symtab']) - - @no_debug_info_test - def test_help_image_du_line_should_work(self): - """Command 'help image du line-table' is not ambiguous and should work.""" - # 'image' is an alias for 'target modules'. - self.expect("help image du line", substrs=[ - 'Dump the line table for one or more compilation units']) - - @no_debug_info_test - def test_help_target_variable_syntax(self): - """Command 'help target variable' should display <variable-name> ...""" - self.expect("help target variable", - substrs=['<variable-name> [<variable-name> [...]]']) - - @no_debug_info_test - def test_help_watchpoint_and_its_args(self): - """Command 'help watchpoint', 'help watchpt-id', and 'help watchpt-id-list' should work.""" - self.expect("help watchpoint", - substrs=['delete', 'disable', 'enable', 'list']) - self.expect("help watchpt-id", - substrs=['<watchpt-id>']) - self.expect("help watchpt-id-list", - substrs=['<watchpt-id-list>']) - - @no_debug_info_test - def test_help_watchpoint_set(self): - """Test that 'help watchpoint set' prints out 'expression' and 'variable' - as the possible subcommands.""" - self.expect("help watchpoint set", - substrs=['The following subcommands are supported:'], - patterns=['expression +--', - 'variable +--']) - - @no_debug_info_test - def test_help_po_hides_options(self): - """Test that 'help po' does not show all the options for expression""" - self.expect( - "help po", - substrs=[ - '--show-all-children', - '--object-description'], - matching=False) - - @no_debug_info_test - def test_help_run_hides_options(self): - """Test that 'help run' does not show all the options for process launch""" - self.expect("help run", - substrs=['--arch', '--environment'], matching=False) - - @no_debug_info_test - def test_help_next_shows_options(self): - """Test that 'help next' shows all the options for thread step-over""" - self.expect("help next", - substrs=['--python-class', '--run-mode'], matching=True) - - @no_debug_info_test - def test_help_provides_alternatives(self): - """Test that help on commands that don't exist provides information on additional help avenues""" - self.expect( - "help thisisnotadebuggercommand", - substrs=[ - "'thisisnotadebuggercommand' is not a known command.", - "Try 'help' to see a current list of commands.", - "Try 'apropos thisisnotadebuggercommand' for a list of related commands.", - "Try 'type lookup thisisnotadebuggercommand' for information on types, methods, functions, modules, etc."], - error=True) - - self.expect( - "help process thisisnotadebuggercommand", - substrs=[ - "'process thisisnotadebuggercommand' is not a known command.", - "Try 'help' to see a current list of commands.", - "Try 'apropos thisisnotadebuggercommand' for a list of related commands.", - "Try 'type lookup thisisnotadebuggercommand' for information on types, methods, functions, modules, etc."]) - - @no_debug_info_test - def test_custom_help_alias(self): - """Test that aliases pick up custom help text.""" - def cleanup(): - self.runCmd('command unalias afriendlyalias', check=False) - self.runCmd('command unalias averyfriendlyalias', check=False) - - self.addTearDownHook(cleanup) - self.runCmd( - 'command alias --help "I am a friendly alias" -- afriendlyalias help') - self.expect( - "help afriendlyalias", - matching=True, - substrs=['I am a friendly alias']) - self.runCmd( - 'command alias --long-help "I am a very friendly alias" -- averyfriendlyalias help') - self.expect("help averyfriendlyalias", matching=True, - substrs=['I am a very friendly alias']) - @no_debug_info_test - def test_alias_prints_origin(self): - """Test that 'help <unique_match_to_alias>' prints the alias origin.""" - def cleanup(): - self.runCmd('command unalias alongaliasname', check=False) - - self.addTearDownHook(cleanup) - self.runCmd('command alias alongaliasname help') - self.expect("help alongaliasna", matching=True, - substrs=["'alongaliasna' is an abbreviation for 'help'"]) - - @no_debug_info_test - def test_hidden_help(self): - self.expect("help -h", - substrs=["_regexp-bt"]) - - @no_debug_info_test - def test_help_ambiguous(self): - self.expect("help g", - substrs=["Help requested with ambiguous command name, possible completions:", - "gdb-remote", "gui"]) - - @no_debug_info_test - def test_help_unknown_flag(self): - self.expect("help -z", error=True, - substrs=["unknown or ambiguous option"]) - - @no_debug_info_test - def test_help_format_output(self): - """Test that help output reaches TerminalWidth.""" - self.runCmd( - 'settings set term-width 108') - self.expect( - "help format", - matching=True, - substrs=['<format> -- One of the format names']) |