summaryrefslogtreecommitdiffstats
path: root/lldb/packages/Python/lldbsuite/test/help
diff options
context:
space:
mode:
authorZachary Turner <zturner@google.com>2015-10-28 17:43:26 +0000
committerZachary Turner <zturner@google.com>2015-10-28 17:43:26 +0000
commitc432c8f856e0bd84de980a9d9bb2d31b06fa95b1 (patch)
tree4efa528e074a6e2df782345e4cd97f5d85d038c4 /lldb/packages/Python/lldbsuite/test/help
parenta8a3bd210086b50242903ed95048fe5e53897878 (diff)
downloadbcm5719-llvm-c432c8f856e0bd84de980a9d9bb2d31b06fa95b1.tar.gz
bcm5719-llvm-c432c8f856e0bd84de980a9d9bb2d31b06fa95b1.zip
Move lldb/test to lldb/packages/Python/lldbsuite/test.
This is the conclusion of an effort to get LLDB's Python code structured into a bona-fide Python package. This has a number of benefits, but most notably the ability to more easily share Python code between different but related pieces of LLDB's Python infrastructure (for example, `scripts` can now share code with `test`). llvm-svn: 251532
Diffstat (limited to 'lldb/packages/Python/lldbsuite/test/help')
-rw-r--r--lldb/packages/Python/lldbsuite/test/help/TestHelp.py165
1 files changed, 165 insertions, 0 deletions
diff --git a/lldb/packages/Python/lldbsuite/test/help/TestHelp.py b/lldb/packages/Python/lldbsuite/test/help/TestHelp.py
new file mode 100644
index 00000000000..90aa2c90b29
--- /dev/null
+++ b/lldb/packages/Python/lldbsuite/test/help/TestHelp.py
@@ -0,0 +1,165 @@
+"""
+Test some lldb help commands.
+
+See also CommandInterpreter::OutputFormattedHelpText().
+"""
+
+from __future__ import print_function
+
+import use_lldb_suite
+
+import os, time
+import lldb
+from lldbtest import *
+
+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 version of LLDB debugger.'])
+ version_str = self.version_number_string()
+ import re
+ match = re.match('[0-9]+', version_str)
+ if sys.platform.startswith("darwin"):
+ search_regexp = ['lldb-' + (version_str if match else '[0-9]+')]
+ else:
+ search_regexp = ['lldb version (\d|\.)+.*$']
+
+ 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' 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 +--'])
OpenPOWER on IntegriCloud