This commit was generated by cvs2svn to track changes on a CVS vendor
[deliverable/binutils-gdb.git] / gdb / testsuite / gdb.c++ / annota2.exp
CommitLineData
c2a1d49a
JM
1# Copyright (C) 1999
2# Free Software Foundation, Inc.
3
4# This program is free software; you can redistribute it and/or modify
5# it under the terms of the GNU General Public License as published by
6# the Free Software Foundation; either version 2 of the License, or
7# (at your option) any later version.
8#
9# This program is distributed in the hope that it will be useful,
10# but WITHOUT ANY WARRANTY; without even the implied warranty of
11# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12# GNU General Public License for more details.
13#
14# You should have received a copy of the GNU General Public License
15# along with this program; if not, write to the Free Software
16# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17
18# Please email any bugs, comments, and/or additions to this file to:
19# bug-gdb@prep.ai.mit.edu
20
21# This file was written by Elena Zannoni (ezannoni@cygnus.com)
22
23if $tracelevel then {
24 strace $tracelevel
25}
26
27
28#
29# test running programs
30#
31set prms_id 0
32set bug_id 0
33
34set testfile "annota2"
35set srcfile ${testfile}.cc
36set binfile ${objdir}/${subdir}/${testfile}
37
38if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug c++ additional_flags=-w}] != "" } {
39 gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
40}
41
42# are we on a target board? If so, don't run these tests.
43# note: this is necessary because we cannot use runto_main (which would
44# work for remote targets too) because of the different prompt we get
45# when using annotation level 2.
46#
47if ![isnative] then {
48 return 0
49}
50
51
52gdb_exit
53gdb_start
54gdb_reinitialize_dir $srcdir/$subdir
55gdb_load ${binfile}
56
57if [target_info exists gdb_stub] {
58 gdb_step_for_stub;
59}
60
61#
62# line number where we need to stop in main
63#
64set main_line 25
65
66# The commands we test here produce many lines of output; disable "press
67# <return> to continue" prompts.
68send_gdb "set height 0\n"
69gdb_expect -re "$gdb_prompt $"
70
71#
72# break at main
73#
74gdb_test "break 25" \
75 "Breakpoint.*at.* file .*$srcfile, line.*" \
76 "breakpoint main"
77
78
79#
80# NOTE: this prompt is OK only when the annotation level is > 1
81# NOTE: When this prompt is in use the gdb_test procedure cannot be used because
82# it assumes that the last char of the gdb_prompt is a white space. This is not
83# true with this annotated prompt. So we must use send_gdb and gdb_expect.
84#
85
86set old_gdb_prompt $gdb_prompt
87set gdb_prompt "\r\n\032\032pre-prompt\r\n$gdb_prompt \r\n\032\032prompt\r\n"
88
89send_gdb "set annotate 2\n"
90gdb_expect {
91 -re "set annotate 2\r\n$gdb_prompt$" { pass "annotation set at level 2" }
92 -re ".*$gdb_prompt$" { fail "annotation set at level 2" }
93 timeout { fail "annotation set at level 2 (timeout)" }
94 }
95
96send_gdb "run\n"
97 gdb_expect {
98 -re "\r\n\032\032post-prompt\r\nStarting program: $binfile \(\r\n\r\n\032\032frames-invalid\)+\(\r\n\r\n\032\032breakpoints-invalid\)*.*\(\r\n\r\n\032\032frames-invalid\)*\r\n\r\n\032\032starting\(\r\n\r\n\032\032frames-invalid\)+\r\n\r\n\032\032breakpoint 1\r\n\r\nBreakpoint 1, \r\n\032\032frame-begin 0 $hex\r\n\r\n\032\032frame-function-name\r\nmain\r\n\032\032frame-args\r\n \\(\\)\r\n\032\032frame-source-begin\r\n at \r\n\032\032frame-source-file\r\n.*annota2.cc\r\n\032\032frame-source-file-end\r\n:\r\n\032\032frame-source-line\r\n$main_line\r\n\032\032frame-source-end\r\n\r\n\r\n\032\032source.*$srcfile:$main_line:.*:beg:$hex\r\n\r\n\032\032frame-end\r\n\r\n\032\032stopped\r\n$gdb_prompt$" \
99 { pass "run until main breakpoint" }
100 -re ".*$gdb_prompt$" { fail "run until main breakpoint" }
101 timeout { fail "run until main breakpoint (timeout)" }
102 }
103
104#
105# print class 'a' with public fields.
106# this will test:
107# annotate-field-begin
108# annotate-field-name-end
109# annotate-field-value
110# annotate-field-end
111#
112send_gdb "print a\n"
113gdb_expect {
114 -re "\r\n\032\032post-prompt\r\n\r\n\032\032value-history-begin 1 -\r\n.*= \r\n\032\032value-history-value\r\n\\{\r\n\032\032field-begin -\r\nx\r\n\032\032field-name-end\r\n = \r\n\032\032field-value\r\n1\r\n\032\032field-end\r\n, \r\n\032\032field-begin -\r\ny\r\n\032\032field-name-end\r\n = \r\n\032\032field-value\r\n2\r\n\032\032field-end\r\n\\}\r\n\r\n\032\032value-history-end\r\n$gdb_prompt$" \
115 { pass "print class" }
116 -re ".*$gdb_prompt$" { fail "print class" }
117 timeout { fail "print class (timeout)" }
118}
119
120#
121# continue until exit
122# this will test:
123# annotate-exited
124#
125send_gdb "continue\n"
126gdb_expect {
127 -re "\r\n\032\032post-prompt\r\nContinuing.\r\n\r\n\032\032starting\r\n\r\n\032\032frames-invalid\r\na.x is 1\r\n\r\n\032\032frames-invalid\r\n\r\n\032\032exited 0\r\n\r\nProgram exited normally.\r\n\r\n\032\032frames-invalid\r\n\r\n\032\032stopped\r\n$gdb_prompt$" \
128 { pass "continue until exit" }
129 -re ".*$gdb_prompt$" { fail "continue to exit" }
130 timeout { fail "continue to exit (timeout)" }
131}
132
133#
134# delete all breakpoints
135#
136send_gdb "delete\n"
137gdb_expect {
138 -re " " {
139 send_gdb "y\n"
140 gdb_expect {
141 -re " " { pass "delete bps" }
142 -re ".*$gdb_prompt$" { fail "delete bps" }
143 timeout { fail "delete bps (timeout)" }
144 }
145 }
146 -re ".*$gdb_prompt$" { fail "delete bps" }
147 timeout { fail "delete bps (timeout)" }
148}
149
150#
151# break at first line of main.
152#
153send_gdb "break 22\n"
154gdb_expect {
155 -re "\r\n\032\032post-prompt\r\n\r\n\032\032breakpoints-invalid\r\nBreakpoint.*at $hex: file.*$srcfile, line.*\r\n$gdb_prompt$" \
156 { pass "breakpoint at main" }
157 -re ".*$gdb_prompt$" { fail "break at main" }
158 timeout { fail "break at main (timeout)" }
159}
160
161#
162# change value of main_line
163#
164set main_line 22
165
166#
167# run program up to breakpoint.
168#
169send_gdb "run\n"
170 gdb_expect {
171 -re "\r\n\032\032post-prompt\r\n.*Starting program: $binfile \(\r\n\r\n\032\032frames-invalid\)+\(\r\n\r\n\032\032breakpoints-invalid\)*.*\(\r\n\r\n\032\032frames-invalid\)*\r\n\r\n\032\032starting\(\r\n\r\n\032\032frames-invalid\)+\r\n\r\n\032\032breakpoint 2\r\n\r\nBreakpoint 2, \r\n\032\032frame-begin 0 $hex\r\n\r\n\032\032frame-function-name\r\nmain\r\n\032\032frame-args\r\n \\(\\)\r\n\032\032frame-source-begin\r\n at \r\n\032\032frame-source-file\r\n.*annota2.cc\r\n\032\032frame-source-file-end\r\n:\r\n\032\032frame-source-line\r\n$main_line\r\n\032\032frame-source-end\r\n\r\n\r\n\032\032source.*$srcfile:$main_line:.*:beg:$hex\r\n\r\n\032\032frame-end\r\n\r\n\032\032stopped\r\n$gdb_prompt$" \
172 { pass "run until main breakpoint" }
173 -re ".*$gdb_prompt$" { fail "run until main breakpoint" }
174 timeout { fail "run until main breakpoint (timeout)" }
175 }
176
177#
178# set up a watch point on a.x
179#
180send_gdb "watch a.x\n"
181gdb_expect {
182 -re "\r\n\032\032post-prompt\r\n\r\n\032\032breakpoints-invalid\r\nWatchpoint 3: a.x\r\n$gdb_prompt$" \
183 { pass "set watch on a.x" }
184 -re ".*$gdb_prompt$" { fail "set watch on a.x" }
185 timeout { fail "set watch on a.x (timeout)" }
186}
187
188#
189# do a next, so that the watchpoint triggers. This will test:
190# annotate-watchpoint
191#
192send_gdb "next\n"
193gdb_expect {
194 -re "\r\n\032\032post-prompt\r\n\r\n\032\032starting\r\n\r\n\032\032frames-invalid\r\n\r\n\032\032frames-invalid\r\n\r\n\032\032frames-invalid\r\n\r\n\032\032watchpoint 3\r\nWatchpoint 3: a.x\r\n\r\nOld value = 0\r\nNew value = 1\r\n\r\n\032\032frame-begin 0 $hex\r\n\r\n\032\032frame-function-name\r\nmain\r\n\032\032frame-args\r\n \\(\\)\r\n\032\032frame-source-begin\r\n at \r\n\032\032frame-source-file\r\n.*$srcfile\r\n\032\032frame-source-file-end\r\n:\r\n\032\032frame-source-line\r\n$decimal\r\n\032\032frame-source-end\r\n\r\n\r\n\032\032source .*$srcfile.*beg:$hex\r\n\r\n\032\032frame-end\r\n\r\n\032\032stopped\r\n$gdb_prompt$" \
195 { pass "watch triggered on a.x" }
196 -re ".*$gdb_prompt$" { fail "watch triggered on a.x" }
197 timeout { fail "watch triggered on a.x (timeout)" }
198}
199
200
201#
202# send ^C to gdb, so that the quit() function gets called
203# and annotate-quit is tested
204# test:
205# annotate-quit
206#
207send_gdb "\003"
208gdb_expect {
209 -re "\r\n\032\032error-begin\r\nQuit\r\n\r\n\032\032quit\r\n$gdb_prompt$" \
210 { pass "annotate-quit" }
211 -re ".*$gdb_prompt$" { fail "annotate-quit" }
212 timeout { fail "annotate-quit (timeout)" }
213}
214
215#
216# FIXME: the testsuite does not currently have tests for
217# annotate_catchpoints and annotate_function_call
218# and a few variants of the annotations that are
219# tested (marked by FIXME on the annot?.exp files)
220#
221
222# reinstall the old prompt for the rest of the testsuite.
223
224set gdb_prompt $old_gdb_prompt
This page took 0.03208 seconds and 4 git commands to generate.