xref: /netbsd-src/external/gpl3/gdb.old/dist/gdb/testsuite/gdb.cp/annota2.exp (revision e6c7e151de239c49d2e38720a061ed9d1fa99309)
1#   Copyright 1999-2017 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
23if { [skip_cplus_tests] } { continue }
24
25standard_testfile .cc
26
27if {[prepare_for_testing "failed to prepare" $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#
37if [is_remote target] then {
38    return 0
39}
40
41set breakpoints_invalid "\r\n\032\032breakpoints-invalid\r\n"
42set frames_invalid "\r\n\032\032frames-invalid\r\n"
43
44#
45# line number where we need to stop in main
46#
47set main_line 25
48
49# The commands we test here produce many lines of output; disable "press
50# <return> to continue" prompts.
51gdb_test_no_output "set height 0"
52
53#
54# break at main
55#
56gdb_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
68set old_gdb_prompt $gdb_prompt
69set gdb_prompt "\r\n\032\032pre-prompt\r\n$gdb_prompt \r\n\032\032prompt\r\n"
70
71send_gdb "set annotate 2\n"
72gdb_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
78gdb_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
93set 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
120gdb_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
133set 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$]
145gdb_test_multiple "continue" "continue until exit" {
146    -re "$pat" {
147	pass "continue until exit"
148    }
149}
150
151#
152# delete all breakpoints
153#
154send_gdb "delete\n"
155gdb_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#
171set pat [multi_line "" \
172	     "\032\032post-prompt" \
173	     "Breakpoint.*at $hex: file.*$srcfile, line.*" \
174	     "\032\032breakpoints-invalid.*" \
175	     $gdb_prompt$]
176
177gdb_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#
186set main_line 22
187
188#
189# run program up to breakpoint.
190#
191
192gdb_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#
201set pat [multi_line "" \
202	     "\032\032post-prompt" \
203	     ".*atchpoint 3: a.x" \
204	     "" \
205	     "\032\032breakpoints-invalid" \
206	     $gdb_prompt$]
207gdb_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#
217set 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
252gdb_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#
265if ![target_info exists gdb,nointerrupts] {
266    send_gdb "\003"
267    gdb_expect {
268	-re "\r\n\032\032error-begin\r\nQuit\r\n\r\n\032\032quit\r\n$gdb_prompt$" \
269	    { pass "annotate-quit" }
270	-re ".*$gdb_prompt$" { fail "annotate-quit" }
271	timeout { fail "annotate-quit (timeout)" }
272    }
273}
274
275#
276# FIXME: the testsuite does not currently have tests for
277#        annotate_catchpoints and annotate_function_call
278#        and a few variants of the annotations that are
279#        tested (marked by FIXME on the annot?.exp files)
280#
281
282# reinstall the old prompt for the rest of the testsuite.
283
284set gdb_prompt $old_gdb_prompt
285
286