]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/testsuite/gdb.base/help.exp
Make first and last lines of 'command help documentation' consistent.
[thirdparty/binutils-gdb.git] / gdb / testsuite / gdb.base / help.exp
CommitLineData
42a4f53d 1# Copyright 1988-2019 Free Software Foundation, Inc.
c906108c
SS
2
3# This program is free software; you can redistribute it and/or modify
4# it under the terms of the GNU General Public License as published by
e22f8b7c 5# the Free Software Foundation; either version 3 of the License, or
c906108c 6# (at your option) any later version.
e22f8b7c 7#
c906108c
SS
8# This program is distributed in the hope that it will be useful,
9# but WITHOUT ANY WARRANTY; without even the implied warranty of
10# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11# GNU General Public License for more details.
e22f8b7c 12#
c906108c 13# You should have received a copy of the GNU General Public License
e22f8b7c 14# along with this program. If not, see <http://www.gnu.org/licenses/>.
c906108c 15
c906108c
SS
16# This file was written by Rob Savoye. (rob@cygnus.com)
17
5941debb
DE
18# Test basic help functionality.
19# This is not intended to test the help text of every command,
20# or even more than a few commands - too much of a maintenance burden.
c906108c
SS
21
22gdb_start
23
5941debb
DE
24# disable pagination
25gdb_test_no_output "set height 0" "disable pagination"
c906108c 26
5941debb 27# Test all the help classes.
a38cd180 28test_class_help "aliases" {"Aliases of other commands\.\[\r\n\]+"}
5941debb
DE
29test_class_help "breakpoints" {
30 "Making program stop at certain points\.\[\r\n\]+"
31}
d86bd7cb
TV
32with_read1_timeout_factor 10 {
33 test_class_help "data" {"Examining data\.\[\r\n\]+"}
34 test_class_help "files" {"Specifying and examining files\.\[\r\n\]+"}
35 test_class_help "internals" {
36 "Maintenance commands\.\[\r\n\]+"
37 "Some gdb commands are provided just for use by gdb maintainers\.\[\r\n\]+"
38 "These commands are subject to frequent change, and may not be as\[\r\n\]+"
39 "well documented as user commands\.\[\r\n\]+"
40 }
5941debb
DE
41}
42test_class_help "obscure" {"Obscure features\.\[\r\n\]+"}
43test_class_help "running" {"Running the program\.\[\r\n\]+"}
44test_class_help "stack" {
45 "Examining the stack\..*\[\r\n\]+"
46 "When the program being debugged stops, gdb selects the innermost frame\.\[\r\n\]+"
47 "The commands below can be used to select other frames by number or address\.\[\r\n\]+"
48}
d86bd7cb
TV
49with_read1_timeout_factor 10 {
50 test_class_help "status" {
51 "Status inquiries\.\[\r\n\]+"
52 }
53 test_class_help "support" {"Support facilities\.\[\r\n\]+"}
54 test_class_help "tracepoints" {
55 "Tracing of program execution without stopping the program\.\[\r\n\]+"
56 }
5941debb 57}
206584bd 58
d86bd7cb
TV
59with_read1_timeout_factor 10 {
60 test_user_defined_class_help
a38cd180 61
d86bd7cb
TV
62 # Test help of an abbreviated command. "break" is picked at random.
63 set help_breakpoint_text "Set breakpoint at specified location\..*"
64 # test help breakpoint "b" abbreviation
65 gdb_test "help b" $help_breakpoint_text "help breakpoint \"b\" abbreviation"
66 # test help breakpoint "br" abbreviation
67 gdb_test "help br" $help_breakpoint_text "help breakpoint \"br\" abbreviation"
68 # test help breakpoint "bre" abbreviation
69 gdb_test "help bre" $help_breakpoint_text "help breakpoint \"bre\" abbreviation"
70 # test help breakpoint "brea" abbreviation
71}
5941debb 72gdb_test "help brea" $help_breakpoint_text "help breakpoint \"brea\" abbreviation"
c906108c 73# test help breakpoint "break" abbreviation
5941debb
DE
74gdb_test "help break" $help_breakpoint_text "help breakpoint \"break\" abbreviation"
75
76# Test help of an aliased command. "bt" is picked at random.
77set help_backtrace_text "Print backtrace of all stack frames, or innermost COUNT frames\..*"
c906108c 78# test help backtrace "bt" abbreviation
5941debb 79gdb_test "help bt" $help_backtrace_text "help backtrace \"bt\" abbreviation"
c906108c 80# test help backtrace
5941debb
DE
81gdb_test "help backtrace" $help_backtrace_text "help backtrace"
82
c906108c 83# test help commands
18da0c51 84gdb_test "help commands" "Set commands to be executed when the given breakpoints are hit\.\[\r\n\]+Give a space-separated breakpoint list as argument after \"commands\"\.\[\r\n\]+A list element can be a breakpoint number \\(e.g. `5'\\) or a range of numbers\[\r\n\]+\\(e.g. `5-7'\\)\.\[\r\n\]+With no argument, the targeted breakpoint is the last one set\.\[\r\n\]+The commands themselves follow starting on the next line\.\[\r\n\]+Type a line containing \"end\" to indicate the end of them\.\[\r\n\]+Give \"silent\" as the first line to make the breakpoint silent;\[\r\n\]+then no output is printed when it is hit, except what the commands print\." "help commands"
5941debb
DE
85
86# Test a prefix command. "delete" is picked at random.
c906108c 87# test help delete "d" abbreviation
a38cd180 88set expected_help_delete {
590042fc
PW
89 "Delete all or some breakpoints\.\[\r\n\]+"
90 "Usage: delete \\\[BREAKPOINTNUM\\\]...\[\r\n\]+"
a38cd180
VP
91 "Arguments are breakpoint numbers with spaces in between\.\[\r\n\]+"
92 "To delete all breakpoints, give no argument\.\[\r\n\]+"
93 "Also a prefix command for deletion of other GDB objects\.\[\r\n\]+"
a38cd180
VP
94}
95test_prefix_command_help {"d" "delete"} $expected_help_delete "help delete \"d\" abbreviation"
c906108c 96# test help delete
a38cd180 97test_prefix_command_help "delete" $expected_help_delete
5941debb
DE
98
99# Make sure help for help itself is present.
c906108c 100# test help help "h" abbreviation
523ac3f9 101gdb_test "help h" "Print list of commands\." "help help \"h\" abbreviation"
c906108c 102# test help help
523ac3f9 103gdb_test "help help" "Print list of commands\." "help help"
5941debb
DE
104
105# The startup banner refers to "show copying" and "show warranty",
106# might as well test for them.
c906108c 107# test help info copying
5941debb
DE
108gdb_test "help show copying" "Conditions for redistributing copies of GDB\." \
109 "help show copying"
c906108c 110# test help info warranty
5941debb
DE
111gdb_test "help show warranty" "Various kinds of warranty you do not have\." \
112 "help show warranty"
a451cb65 113
5941debb 114# Test a few other random "help show" commands.
c906108c 115# test help show commands
523ac3f9 116gdb_test "help show commands" "Show the history of commands you typed\.\[\r\n\]+You can supply a command number to start with, or a `\[+\]' to start after\[\r\n\]+the previous command number shown\." "help show commands"
c906108c 117# test help show confirm
523ac3f9 118gdb_test "help show confirm" "Show whether to confirm potentially dangerous operations\." "help show confirm"
96b3d632 119
c906108c 120# test help info bogus-gdb-command
523ac3f9 121gdb_test "help info bogus-gdb-command" "Undefined info command: \"bogus-gdb-command\"\. Try \"help info\"\." "help info bogus-gdb-command"
c906108c 122# test help gotcha
523ac3f9 123gdb_test "help gotcha" "Undefined command: \"gotcha\"\. Try \"help\"\." "help gotcha"
5941debb 124
6837a0a2 125# test apropos regex
590042fc 126gdb_test "apropos \\\(print\[\^\[ bsiedf\\\".-\]\\\)" "handle -- Specify how to handle signals\."
6837a0a2 127# test apropos >1 word string
590042fc 128gdb_test "apropos handle signal" "handle -- Specify how to handle signals\."
6837a0a2 129# test apropos apropos
ed3ef339 130gdb_test "apropos apropos" "apropos -- Search for commands matching a REGEXP.*"