You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			242 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
		
		
			
		
	
	
			242 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|   | """
 | ||
|  | Test some lldb help commands. | ||
|  | 
 | ||
|  | See also CommandInterpreter::OutputFormattedHelpText(). | ||
|  | """
 | ||
|  | 
 | ||
|  | from __future__ import print_function | ||
|  | 
 | ||
|  | 
 | ||
|  | import os | ||
|  | import time | ||
|  | 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() | ||
|  |             pass | ||
|  | 
 | ||
|  |         # 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_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']) |