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