Use multi_line to make pattern more human readable
[deliverable/binutils-gdb.git] / gdb / testsuite / gdb.cp / annota2.exp
1 # Copyright 1999-2015 Free Software Foundation, Inc.
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
5 # the Free Software Foundation; either version 3 of the License, or
6 # (at your option) any later version.
7 #
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.
12 #
13 # You should have received a copy of the GNU General Public License
14 # along with this program. If not, see <http://www.gnu.org/licenses/>.
15
16 # This file was written by Elena Zannoni (ezannoni@cygnus.com)
17
18
19 #
20 # test running programs
21 #
22
23 if { [skip_cplus_tests] } { continue }
24
25 standard_testfile .cc
26
27 if {[prepare_for_testing $testfile.exp $testfile $srcfile \
28 {debug c++ nowarnings}]} {
29 return -1
30 }
31
32 # are we on a target board? If so, don't run these tests.
33 # note: this is necessary because we cannot use runto_main (which would
34 # work for remote targets too) because of the different prompt we get
35 # when using annotation level 2.
36 #
37 if [is_remote target] then {
38 return 0
39 }
40
41 set breakpoints_invalid "\r\n\032\032breakpoints-invalid\r\n"
42 set frames_invalid "\r\n\032\032frames-invalid\r\n"
43
44 #
45 # line number where we need to stop in main
46 #
47 set main_line 25
48
49 # The commands we test here produce many lines of output; disable "press
50 # <return> to continue" prompts.
51 gdb_test_no_output "set height 0"
52
53 #
54 # break at main
55 #
56 gdb_test "break 25" \
57 "Breakpoint.*at.* file .*$srcfile, line.*" \
58 "breakpoint main"
59
60
61 #
62 # NOTE: this prompt is OK only when the annotation level is > 1
63 # NOTE: When this prompt is in use the gdb_test procedure cannot be used because
64 # it assumes that the last char of the gdb_prompt is a white space. This is not
65 # true with this annotated prompt. So we must use send_gdb and gdb_expect.
66 #
67
68 set old_gdb_prompt $gdb_prompt
69 set gdb_prompt "\r\n\032\032pre-prompt\r\n$gdb_prompt \r\n\032\032prompt\r\n"
70
71 send_gdb "set annotate 2\n"
72 gdb_expect {
73 -re "set annotate 2\r\n$gdb_prompt$" { pass "annotation set at level 2" }
74 -re ".*$gdb_prompt$" { fail "annotation set at level 2" }
75 timeout { fail "annotation set at level 2 (timeout)" }
76 }
77
78 gdb_test_multiple "run" "run until main breakpoint" {
79 -re "$main_line.*$gdb_prompt$" {
80 pass "run until main breakpoint"
81 }
82 }
83
84 #
85 # print class 'a' with public fields.
86 # this will test:
87 # annotate-field-begin
88 # annotate-field-name-end
89 # annotate-field-value
90 # annotate-field-end
91 #
92
93 set pat [multi_line "" \
94 "\032\032post-prompt" \
95 "" \
96 "\032\032value-history-begin 1 -" \
97 ".*= " \
98 "\032\032value-history-value" \
99 "\\{" \
100 "\032\032field-begin -" \
101 "x" \
102 "\032\032field-name-end" \
103 " = " \
104 "\032\032field-value" \
105 "1" \
106 "\032\032field-end" \
107 ", " \
108 "\032\032field-begin -" \
109 "y" \
110 "\032\032field-name-end" \
111 " = " \
112 "\032\032field-value" \
113 "2" \
114 "\032\032field-end" \
115 "\\}" \
116 "" \
117 "\032\032value-history-end" \
118 $gdb_prompt$]
119
120 gdb_test_multiple "print a" "print class" {
121 -re "$pat" {
122 pass "print class"
123 }
124 }
125
126 #
127 # continue until exit
128 # this will test:
129 # annotate-exited
130 # `a.x is 1' is asynchronous regarding to `frames-invalid'.
131 #
132
133 set pat [multi_line "" \
134 "\032\032post-prompt" \
135 "Continuing." \
136 "" \
137 "\032\032starting" \
138 "\(${frames_invalid}\)*a.x is 1" \
139 "\(${frames_invalid}\)*"\
140 "\032\032exited 0" \
141 "$inferior_exited_re normally." \
142 "" \
143 "\032\032stopped" \
144 $gdb_prompt$]
145 gdb_test_multiple "continue" "continue until exit" {
146 -re "$pat" {
147 pass "continue until exit"
148 }
149 }
150
151 #
152 # delete all breakpoints
153 #
154 send_gdb "delete\n"
155 gdb_expect {
156 -re ".*Delete all breakpoints. \\(y or n\\) \r\n\032\032query.*$" {
157 send_gdb "y\n"
158 gdb_expect {
159 -re "\r\n\032\032post-query\r\n${breakpoints_invalid}$gdb_prompt$" { pass "delete bps" }
160 -re ".*$gdb_prompt$" { fail "delete bps" }
161 timeout { fail "delete bps (timeout)" }
162 }
163 }
164 -re ".*$gdb_prompt$" { fail "delete bps" }
165 timeout { fail "delete bps (timeout)" }
166 }
167
168 #
169 # break at first line of main.
170 #
171 set pat [multi_line "" \
172 "\032\032post-prompt" \
173 "Breakpoint.*at $hex: file.*$srcfile, line.*" \
174 "\032\032breakpoints-invalid.*" \
175 $gdb_prompt$]
176
177 gdb_test_multiple "break 22" "break at main" {
178 -re "$pat" {
179 pass "breakpoint at main"
180 }
181 }
182
183 #
184 # change value of main_line
185 #
186 set main_line 22
187
188 #
189 # run program up to breakpoint.
190 #
191
192 gdb_test_multiple "run" "run until main breakpoint" {
193 -re "$main_line.*$gdb_prompt$" {
194 pass "run until main breakpoint"
195 }
196 }
197
198 #
199 # set up a watch point on a.x
200 #
201 set pat [multi_line "" \
202 "\032\032post-prompt" \
203 ".*atchpoint 3: a.x" \
204 "" \
205 "\032\032breakpoints-invalid" \
206 $gdb_prompt$]
207 gdb_test_multiple "watch a.x" "set watch on a.x" {
208 -re "$pat" {
209 pass "set watch on a.x"
210 }
211 }
212
213 #
214 # do a next, so that the watchpoint triggers. This will test:
215 # annotate-watchpoint
216 #
217 set pat [multi_line "" \
218 "\032\032post-prompt" \
219 "" \
220 "\032\032starting" \
221 "\(${frames_invalid}\)*${breakpoints_invalid}" \
222 "\032\032watchpoint 3" \
223 ".*atchpoint 3: a.x" \
224 "" \
225 "Old value = 0" \
226 "New value = 1" \
227 "" \
228 "\032\032frame-begin 0 $hex" \
229 "" \
230 "\032\032frame-function-name" \
231 "main" \
232 "\032\032frame-args" \
233 " \\(\\)" \
234 "\032\032frame-source-begin" \
235 " at " \
236 "\032\032frame-source-file" \
237 ".*$srcfile" \
238 "\032\032frame-source-file-end" \
239 ":" \
240 "\032\032frame-source-line" \
241 "$decimal" \
242 "\032\032frame-source-end" \
243 "" \
244 "" \
245 "\032\032source .*$srcfile.*beg:$hex" \
246 "" \
247 "\032\032frame-end" \
248 "" \
249 "\032\032stopped" \
250 $gdb_prompt$]
251
252 gdb_test_multiple "next" "watch triggered on a.x" {
253 -re "$pat" {
254 pass "watch triggered on a.x"
255 }
256 }
257
258
259 #
260 # send ^C to gdb, so that the quit() function gets called
261 # and annotate-quit is tested
262 # test:
263 # annotate-quit
264 #
265 send_gdb "\003"
266 gdb_expect {
267 -re "\r\n\032\032error-begin\r\nQuit\r\n\r\n\032\032quit\r\n$gdb_prompt$" \
268 { pass "annotate-quit" }
269 -re ".*$gdb_prompt$" { fail "annotate-quit" }
270 timeout { fail "annotate-quit (timeout)" }
271 }
272
273 #
274 # FIXME: the testsuite does not currently have tests for
275 # annotate_catchpoints and annotate_function_call
276 # and a few variants of the annotations that are
277 # tested (marked by FIXME on the annot?.exp files)
278 #
279
280 # reinstall the old prompt for the rest of the testsuite.
281
282 set gdb_prompt $old_gdb_prompt
283
This page took 0.036412 seconds and 4 git commands to generate.