annota2.exp revision 1.8
1#   Copyright 1999-2019 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# This testcase cannot use runto_main because of the different prompt
33# we get when using annotation level 2.
34#
35if ![target_can_use_run_cmd] {
36    return 0
37}
38
39set breakpoints_invalid "\r\n\032\032breakpoints-invalid\r\n"
40set frames_invalid "\r\n\032\032frames-invalid\r\n"
41
42#
43# line number where we need to stop in main
44#
45set main_line 25
46
47# The commands we test here produce many lines of output; disable "press
48# <return> to continue" prompts.
49gdb_test_no_output "set height 0"
50
51#
52# break at main
53#
54gdb_test "break 25" \
55    "Breakpoint.*at.* file .*$srcfile, line.*" \
56    "breakpoint main"
57
58
59#
60# NOTE: this prompt is OK only when the annotation level is > 1
61# NOTE: When this prompt is in use the gdb_test procedure cannot be used because
62# it assumes that the last char of the gdb_prompt is a white space. This is not
63# true with this annotated prompt. So we must use send_gdb and gdb_expect.
64#
65
66set old_gdb_prompt $gdb_prompt
67set gdb_prompt "\r\n\032\032pre-prompt\r\n$gdb_prompt \r\n\032\032prompt\r\n"
68
69send_gdb "set annotate 2\n"
70gdb_expect {
71    -re "set annotate 2\r\n$gdb_prompt$" { pass "annotation set at level 2" }
72    -re ".*$gdb_prompt$"       { fail "annotation set at level 2" }
73    timeout	            { fail "annotation set at level 2 (timeout)" }
74  }
75
76gdb_test_multiple "run" "run until main breakpoint" {
77    -re "$main_line.*$gdb_prompt$" {
78	pass "run until main breakpoint"
79    }
80}
81
82#
83# print class 'a' with public fields.
84# this will test:
85# annotate-field-begin
86# annotate-field-name-end
87# annotate-field-value
88# annotate-field-end
89#
90
91set pat [multi_line "" \
92	     "\032\032post-prompt" \
93	     "" \
94	     "\032\032value-history-begin 1 -" \
95	     ".*= " \
96	     "\032\032value-history-value" \
97	     "\\{" \
98	     "\032\032field-begin -" \
99	     "x" \
100	     "\032\032field-name-end" \
101	     " = " \
102	     "\032\032field-value" \
103	     "1" \
104	     "\032\032field-end" \
105	     ", " \
106	     "\032\032field-begin -" \
107	     "y" \
108	     "\032\032field-name-end" \
109	     " = " \
110	     "\032\032field-value" \
111	     "2" \
112	     "\032\032field-end" \
113	     "\\}" \
114	     "" \
115	     "\032\032value-history-end" \
116	     $gdb_prompt$]
117
118gdb_test_multiple "print a" "print class" {
119    -re "$pat" {
120	pass "print class"
121    }
122}
123
124#
125# continue until exit
126# this will test:
127# annotate-exited
128# `a.x is 1' is asynchronous regarding to `frames-invalid'.
129#
130
131set pat [multi_line "" \
132	     "\032\032post-prompt" \
133	     "Continuing." \
134	     "" \
135	     "\032\032starting" \
136	     "\(${frames_invalid}\)*a.x is 1" \
137	     "\(${frames_invalid}\)*"\
138	     "\032\032exited 0" \
139	     "$inferior_exited_re normally." \
140	     "" \
141	     "\032\032stopped" \
142	     $gdb_prompt$]
143gdb_test_multiple "continue" "continue until exit" {
144    -re "$pat" {
145	pass "continue until exit"
146    }
147}
148
149#
150# delete all breakpoints
151#
152send_gdb "delete\n"
153gdb_expect {
154  -re ".*Delete all breakpoints. \\(y or n\\) \r\n\032\032query.*$" {
155           send_gdb "y\n"
156           gdb_expect {
157	     -re "\r\n\032\032post-query\r\n${breakpoints_invalid}$gdb_prompt$" { pass "delete bps" }
158	     -re ".*$gdb_prompt$" { fail "delete bps" }
159	     timeout  { fail "delete bps (timeout)" }
160	 }
161     }
162  -re ".*$gdb_prompt$" { fail "delete bps" }
163  timeout  { fail "delete bps (timeout)" }
164}
165
166#
167# break at first line of main.
168#
169set pat [multi_line "" \
170	     "\032\032post-prompt" \
171	     "Breakpoint.*at $hex: file.*$srcfile, line.*" \
172	     "\032\032breakpoints-invalid.*" \
173	     $gdb_prompt$]
174
175gdb_test_multiple "break 22" "break at main" {
176    -re  "$pat" {
177	pass "breakpoint at main"
178    }
179}
180
181#
182# change value of main_line
183#
184set main_line 22
185
186#
187# run program up to breakpoint.
188#
189
190gdb_test_multiple "run" "run until main breakpoint" {
191    -re "$main_line.*$gdb_prompt$"    {
192	pass "run until main breakpoint"
193    }
194}
195
196#
197# set up a watch point on a.x
198#
199set pat [multi_line "" \
200	     "\032\032post-prompt" \
201	     ".*atchpoint 3: a.x" \
202	     "" \
203	     "\032\032breakpoints-invalid" \
204	     $gdb_prompt$]
205gdb_test_multiple "watch a.x" "set watch on a.x" {
206    -re "$pat" {
207	pass "set watch on a.x"
208    }
209}
210
211#
212# do a next, so that the watchpoint triggers. This will test:
213# annotate-watchpoint
214#
215set pat [multi_line "" \
216	     "\032\032post-prompt" \
217	     "" \
218	     "\032\032starting" \
219	     "\(${frames_invalid}\)*${breakpoints_invalid}" \
220	     "\032\032watchpoint 3" \
221	     ".*atchpoint 3: a.x" \
222	     "" \
223	     "Old value = 0" \
224	     "New value = 1" \
225	     "" \
226	     "\032\032frame-begin 0 $hex" \
227	     "" \
228	     "\032\032frame-function-name" \
229	     "main" \
230	     "\032\032frame-args" \
231	     " \\(\\)" \
232	     "\032\032frame-source-begin" \
233	     " at " \
234	     "\032\032frame-source-file" \
235	     ".*$srcfile" \
236	     "\032\032frame-source-file-end" \
237	     ":" \
238	     "\032\032frame-source-line" \
239	     "$decimal" \
240	     "\032\032frame-source-end" \
241	     "" \
242	     "" \
243	     "\032\032source .*$srcfile.*beg:$hex" \
244	     "" \
245	     "\032\032frame-end" \
246	     "" \
247	     "\032\032stopped" \
248	     $gdb_prompt$]
249
250gdb_test_multiple "next" "watch triggered on a.x" {
251    -re "$pat" {
252	pass "watch triggered on a.x"
253    }
254}
255
256
257#
258# send ^C to gdb, so that the quit() function gets called
259# and annotate-quit is tested
260# test:
261# annotate-quit
262#
263if ![target_info exists gdb,nointerrupts] {
264    send_gdb "\003"
265    gdb_expect {
266	-re "\r\n\032\032error-begin\r\nQuit\r\n\r\n\032\032quit\r\n$gdb_prompt$" \
267	    { pass "annotate-quit" }
268	-re ".*$gdb_prompt$" { fail "annotate-quit" }
269	timeout { fail "annotate-quit (timeout)" }
270    }
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
282set gdb_prompt $old_gdb_prompt
283
284