2013-01-21 Marc Khouzam <marc.khouzam@ericsson.com>
[deliverable/binutils-gdb.git] / gdb / testsuite / gdb.mi / mi-break.exp
CommitLineData
8acc9f48 1# Copyright 1999-2013 Free Software Foundation, Inc.
fb40c209
AC
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
fb40c209 6# (at your option) any later version.
e22f8b7c 7#
fb40c209
AC
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#
fb40c209 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/>.
fb40c209 15
fb40c209
AC
16#
17# Test essential Machine interface (MI) operations
18#
19# Verify that, using the MI, we can run a simple program and perform basic
20# debugging activities like: insert breakpoints, run the program,
21# step, next, continue until it ends and, last but not least, quit.
22#
23# The goal is not to test gdb functionality, which is done by other tests,
24# but to verify the correct output response to MI operations.
25#
26
27load_lib mi-support.exp
b30bf9ee 28set MIFLAGS "-i=mi"
fb40c209
AC
29
30gdb_exit
31if [mi_gdb_start] {
32 continue
33}
34
298a9cf0
TT
35standard_testfile basics.c
36
9357e021 37if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
b60f0898
JB
38 untested mi-break.exp
39 return -1
fb40c209
AC
40}
41
42mi_delete_breakpoints
43mi_gdb_reinitialize_dir $srcdir/$subdir
44mi_gdb_load ${binfile}
45
deea8bb0
MC
46# Locate line numbers in basics.c.
47set line_callee4_head [gdb_get_line_number "callee4 ("]
48set line_callee4_body [expr $line_callee4_head + 2]
49set line_callee3_head [gdb_get_line_number "callee3 ("]
50set line_callee3_body [expr $line_callee3_head + 2]
51set line_callee2_head [gdb_get_line_number "callee2 ("]
52set line_callee2_body [expr $line_callee2_head + 2]
53set line_callee1_head [gdb_get_line_number "callee1 ("]
54set line_callee1_body [expr $line_callee1_head + 2]
55set line_main_head [gdb_get_line_number "main ("]
56set line_main_body [expr $line_main_head + 2]
dd322c54
JK
57set line_callme_head [gdb_get_line_number "callme ("]
58set line_callme_body [expr $line_callme_head + 2]
deea8bb0 59
38fcd64c
DJ
60set fullname "fullname=\"${fullname_syntax}${srcfile}\""
61
fb40c209
AC
62proc test_tbreak_creation_and_listing {} {
63 global mi_gdb_prompt
64 global srcfile
65 global hex
deea8bb0
MC
66 global line_callee4_head line_callee4_body
67 global line_callee3_head line_callee3_body
68 global line_callee2_head line_callee2_body
69 global line_callee1_head line_callee1_body
70 global line_main_head line_main_body
38fcd64c 71 global fullname
fb40c209
AC
72
73 # Insert some breakpoints and list them
74 # Also, disable some so they do not interfere with other tests
75 # Tests:
76 # -break-insert -t main
77 # -break-insert -t basics.c:callee2
deea8bb0
MC
78 # -break-insert -t basics.c:$line_callee3_head
79 # -break-insert -t srcfile:$line_callee4_head
fb40c209
AC
80 # -break-list
81
d24317b4 82 mi_create_breakpoint "-t main" 1 del main ".*basics.c" $line_main_body $hex \
fb40c209
AC
83 "break-insert -t operation"
84
d24317b4 85 mi_create_breakpoint "-t basics.c:callee2" 2 del callee2 ".*basics.c" $line_callee2_body $hex \
fb40c209
AC
86 "insert temp breakpoint at basics.c:callee2"
87
56ef84b1 88 mi_create_breakpoint "-t basics.c:$line_callee3_head" 3 del callee3 ".*basics.c" $line_callee3_head $hex \
b40e7bf3 89 "insert temp breakpoint at basics.c:\$line_callee3_head"
fb40c209 90
deea8bb0 91 # Getting the quoting right is tricky. That is "\"<file>\":$line_callee4_head"
56ef84b1 92 mi_create_breakpoint "-t \"\\\"${srcfile}\\\":$line_callee4_head\"" 4 del callee4 ".*basics.c" $line_callee4_head $hex \
deea8bb0 93 "insert temp breakpoint at \"<fullfilename>\":\$line_callee4_head"
fb40c209
AC
94
95 mi_gdb_test "666-break-list" \
998580f1 96 "666\\\^done,BreakpointTable=\{nr_rows=\".\",nr_cols=\".\",hdr=\\\[\{width=\".*\",alignment=\".*\",col_name=\"number\",colhdr=\"Num\"\}.*colhdr=\"Type\".*colhdr=\"Disp\".*colhdr=\"Enb\".*colhdr=\"Address\".*colhdr=\"What\".*\\\],body=\\\[bkpt=\{number=\"1\",type=\"breakpoint\",disp=\"del\",enabled=\"y\",addr=\"$hex\",func=\"main\",file=\".*basics.c\",${fullname},line=\"$line_main_body\",thread-groups=\\\[\"i1\"\\\],times=\"0\",original-location=\".*\"\}.*\\\]\}" \
fb40c209
AC
97 "list of breakpoints"
98
99 mi_gdb_test "777-break-delete" \
100 "777\\^done" \
101 "delete temp breakpoints"
102}
103
104proc test_rbreak_creation_and_listing {} {
105 global mi_gdb_prompt
106 global srcfile
107 global hex
deea8bb0
MC
108 global line_callee4_head line_callee4_body
109 global line_callee3_head line_callee3_body
110 global line_callee2_head line_callee2_body
111 global line_callee1_head line_callee1_body
112 global line_main_head line_main_body
fb40c209
AC
113
114 # Insert some breakpoints and list them
115 # Also, disable some so they do not interfere with other tests
116 # Tests:
117 # -break-insert -r main
118 # -break-insert -r callee2
119 # -break-insert -r callee
120 # -break-insert -r .*llee
121 # -break-list
122
18b5ff1b 123 setup_kfail "*-*-*" mi/14270
fb40c209 124 mi_gdb_test "122-break-insert -r main" \
deea8bb0 125 "122\\^done,bkpt=\{number=\"5\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_main_body\"\}" \
fb40c209
AC
126 "break-insert -r operation"
127
18b5ff1b 128 setup_kfail "*-*-*" mi/14270
fb40c209 129 mi_gdb_test "133-break-insert -r callee2" \
deea8bb0 130 "133\\^done,bkpt=\{number=\"6\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee2_body\"\}" \
fb40c209
AC
131 "insert breakpoint with regexp callee2"
132
18b5ff1b 133 setup_kfail "*-*-*" mi/14270
fb40c209 134 mi_gdb_test "144-break-insert -r callee" \
deea8bb0 135 "144\\^done,bkpt=\{number=\"7\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee1_body\"\},bkpt=\{number=\"8\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee2_body\"\},bkpt=\{number=\"9\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee3_body\"\},bkpt=\{number=\"10\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee4_body\"\}" \
fb40c209
AC
136 "insert breakpoint with regexp callee"
137
18b5ff1b 138 setup_kfail "*-*-*" mi/14270
fb40c209 139 mi_gdb_test "155-break-insert -r \.\*llee" \
deea8bb0 140 "155\\^done,bkpt=\{number=\"11\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee1_body\"\},bkpt=\{number=\"12\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee2_body\"\},bkpt=\{number=\"13\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee3_body\"\},bkpt=\{number=\"14\",addr=\"$hex\",file=\".*basics.c\",line=\"$line_callee4_body\"\}" \
fb40c209
AC
141 "insert breakpoint with regexp .*llee"
142
18b5ff1b 143 setup_kfail "*-*-*" mi/14270
fb40c209 144 mi_gdb_test "166-break-list" \
998580f1 145 "1\\\^done,BreakpointTable=\{nr_rows=\".\",nr_cols=\".\",hdr=\\\[\{width=\".*\",alignment=\".*\",col_name=\"number\",colhdr=\"Num\"\}.*colhdr=\"Type\".*colhdr=\"Disp\".*colhdr=\"Enb\".*colhdr=\"Address\".*colhdr=\"What\".*\\\],body=\\\[bkpt=\{number=\"5\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"$hex\",func=\"main\",file=\".*basics.c\",line=\"$line_main_body\",thread-groups=\\\[\"i1\"\\\],times=\"0\"\},.*\}\\\]\}" \
fb40c209
AC
146 "list of breakpoints"
147
148 mi_gdb_test "177-break-delete" \
149 "177\\^done" \
150 "delete temp breakpoints"
151}
152
558a9d82
YQ
153proc test_abreak_creation {} {
154 mi_create_varobj tpnum \$tpnum "create local variable tpnum"
155 # Test that $tpnum is not set before creating a tracepoint.
156 mi_gdb_test "521-var-evaluate-expression tpnum" \
157 "521\\^done,value=\"void\"" "eval tpnum before tracepoint"
158
159 mi_gdb_test "522-break-insert -a main" \
160 "522\\^done,bkpt=\{number=\"10\",type=\"tracepoint\".*\"\}" \
161 "break-insert -a operation"
162
163 mi_gdb_test "523-var-update tpnum" \
164 "523\\^done,changelist=\\\[\{name=\"tpnum\",in_scope=\"true\",type_changed=\"false\",has_more=\"0\"\}\\\]" \
165 "update tpnum"
166 # Test that $tpnum is updated after creating a tracepoint.
167 mi_gdb_test "524-var-evaluate-expression tpnum" \
168 "524\\^done,value=\"10\"" "eval tpnum after tracepoint"
169}
170
60c46647
VP
171proc test_ignore_count {} {
172 global mi_gdb_prompt
dd322c54 173 global line_callme_body
60c46647
VP
174
175 mi_gdb_test "-break-insert -i 1 callme" \
176 "\\^done.*ignore=\"1\".*" \
177 "insert breakpoint with ignore count at callme"
178
179 mi_run_cmd
180
dd322c54 181 mi_expect_stop "breakpoint-hit" "callme" "\{name=\"i\",value=\"2\"\}" ".*basics.c" $line_callme_body \
83408de7 182 {"" "disp=\"keep\"" } "run to breakpoint with ignore count"
60c46647
VP
183}
184
723a2275
VP
185proc test_error {} {
186 global mi_gdb_prompt
187
188 mi_gdb_test "-break-insert function_that_does_not_exist" \
189 ".*\\^error,msg=\"Function \\\\\"function_that_does_not_exist\\\\\" not defined.\"" \
190 "breakpoint at nonexistent function"
98deb0da
VP
191
192 # We used to have a bug whereby -break-insert that failed would not
193 # clear some event hooks. As result, whenever we evaluate expression
194 # containing function call, the internal breakpoint created to handle
195 # function call would be reported, messing up MI output.
196 mi_gdb_test "-var-create V * return_1()" \
0cc7d26f 197 "\\^done,name=\"V\",numchild=\"0\",value=\"1\",type=\"int\",has_more=\"0\"" \
98deb0da
VP
198 "create varobj for function call"
199
200 mi_gdb_test "-var-update *" \
201 "\\^done,changelist=\\\[\\\]" \
202 "update varobj for function call"
723a2275
VP
203}
204
41447f92
VP
205proc test_disabled_creation {} {
206 global mi_gdb_prompt
207 global hex
208 global line_callee2_body
209
210 mi_gdb_test "-break-insert -d basics.c:callee2" \
998580f1 211 "\\^done,bkpt=\{number=\"6\",type=\"breakpoint\",disp=\"keep\",enabled=\"n\",addr=\"$hex\",func=\"callee2\",file=\".*basics.c\",fullname=\".*\",line=\"$line_callee2_body\",thread-groups=\\\[\"i1\"\\\],times=\"0\",original-location=\".*\"\}" \
41447f92
VP
212 "test disabled creation"
213
214 mi_gdb_test "-break-delete" \
215 "\\^done" \
216 "test disabled creation: cleanup"
217}
218
48cb2d85
VP
219proc test_breakpoint_commands {} {
220 global line_callee2_body
221 global hex
222 global fullname
223
224 mi_create_breakpoint "basics.c:callee2" 7 keep callee2 ".*basics.c" $line_callee2_body $hex \
225 "breakpoint commands: insert breakpoint at basics.c:callee2"
226
227 mi_gdb_test "-break-commands 7 \"print 10\" \"continue\"" \
228 "\\^done" \
229 "breakpoint commands: set commands"
230
231 mi_gdb_test "-break-info 7" \
998580f1 232 "\\^done,BreakpointTable=\{nr_rows=\".\",nr_cols=\".\",hdr=\\\[\{width=\".*\",alignment=\".*\",col_name=\"number\",colhdr=\"Num\"\}.*colhdr=\"Type\".*colhdr=\"Disp\".*colhdr=\"Enb\".*colhdr=\"Address\".*colhdr=\"What\".*\\\],body=\\\[bkpt=\{number=\"7\",type=\"breakpoint\",disp=\"keep\",enabled=\"y\",addr=\"$hex\",func=\"callee2\",file=\".*basics.c\",${fullname},line=\"$line_callee2_body\",thread-groups=\\\[\"i1\"\\\],times=\"0\",script=\{\"print 10\",\"continue\"\},original-location=\".*\"\}.*\\\]\}" \
48cb2d85
VP
233 "breakpoint commands: check that commands are set"
234
235 mi_gdb_test "-break-commands 7" \
236 "\\^done" \
237 "breakpoint commands: clear commands"
238
239 mi_list_breakpoints [list [list 7 "keep" "callee2" "basics.c" "$line_callee2_body" $hex]] \
240 "breakpoint commands: check that commands are cleared"
5d4e2b76
VP
241
242 mi_run_to_main
243
244 mi_create_breakpoint "basics.c:callee2" 9 keep callee2 ".*basics.c" $line_callee2_body $hex \
245 "breakpoint commands: insert breakpoint at basics.c:callee2, again"
246
247 mi_gdb_test "-break-commands 9 \"set \$i=0\" \"while \$i<10\" \"print \$i\" \"set \$i=\$i+1\" \"end\" \"continue\" " \
248 "\\^done" \
249 "breakpoint commands: set commands"
250
4a07b7da
PA
251 mi_send_resuming_command "exec-continue" "breakpoint commands: continue"
252
253 set test "intermediate stop and continue"
254 gdb_expect {
255 -re ".*\\\$1 = 0.*\\\$10 = 9.*\\*running" {
256 pass $test
257 }
258 timeout {
259 fail $test
260 }
261 }
262
263 mi_expect_stop "exited-normally" "" "" "" "" "" "test hitting breakpoint with commands"
48cb2d85
VP
264}
265
fb40c209
AC
266test_tbreak_creation_and_listing
267test_rbreak_creation_and_listing
268
60c46647
VP
269test_ignore_count
270
723a2275
VP
271test_error
272
41447f92
VP
273test_disabled_creation
274
48cb2d85
VP
275test_breakpoint_commands
276
558a9d82
YQ
277test_abreak_creation
278
fb40c209
AC
279mi_gdb_exit
280return 0
This page took 2.59066 seconds and 4 git commands to generate.