1 # Copyright
(C
) 2010-2022 Free Software Foundation
, Inc.
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.
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.
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
/>.
16 # This file is part of the GDB testsuite. It tests the mechanism
17 # exposing breakpoints to Python.
19 load_lib gdb
-python.exp
23 set options
{debug c
++}
25 if { [prepare_for_testing
"failed to prepare" ${testfile} ${srcfile} ${options}] } {
29 # Skip all tests
if Python scripting is not enabled.
30 if { [skip_python_tests
] } { continue }
32 proc_with_prefix test_bkpt_basic
{ } {
33 global srcfile testfile hex decimal
35 # Start with a fresh gdb.
36 clean_restart $
{testfile
}
38 # We should start with no breakpoints.
39 gdb_test
"python print (gdb.breakpoints())" "\\(\\)"
41 if ![runto_main
] then {
45 # Now there should be one breakpoint
: main.
46 gdb_py_test_silent_cmd
"python blist = gdb.breakpoints()" \
47 "Get Breakpoint List" 0
48 gdb_test
"python print (blist\[0\])" \
49 "<gdb.Breakpoint object at $hex>" "Check obj exists @main"
50 gdb_test
"python print (blist\[0\].location)" \
51 "main." "Check breakpoint location @main"
52 gdb_test
"python print (blist\[0\].pending)" "False" \
53 "Check pending status of main breakpoint"
55 set mult_line
[gdb_get_line_number
"Break at multiply."]
56 gdb_breakpoint $
{mult_line
}
57 gdb_continue_to_breakpoint
"Break at multiply" \
58 ".*Break at multiply.*"
60 # Check that the Python breakpoint code noted the addition of a
61 # breakpoint
"behind the scenes".
62 gdb_py_test_silent_cmd
"python blist = gdb.breakpoints()" \
63 "Get Breakpoint List" 0
64 gdb_test
"python print (len(blist))" \
65 "2" "Check for two breakpoints"
66 gdb_test
"python print (blist\[0\])" \
67 "<gdb.Breakpoint object at $hex>" "Check obj exists @main 2"
68 gdb_test
"python print (blist\[0\].location)" \
69 "main." "Check breakpoint location @main 2"
70 gdb_test
"python print (blist\[1\])" \
71 "<gdb.Breakpoint object at $hex>" "Check obj exists @mult_line"
73 gdb_test
"python print (blist\[1\].location)" \
74 "py-breakpoint\.c:${mult_line}*" \
75 "check breakpoint location @mult_line"
77 # Check hit and ignore counts.
78 gdb_test
"python print (blist\[1\].hit_count)" \
79 "1" "Check breakpoint hit count @1"
80 gdb_py_test_silent_cmd
"python blist\[1\].ignore_count = 4" \
81 "Set breakpoint hit count" 0
82 gdb_continue_to_breakpoint
"Break at multiply @6" \
83 ".*Break at multiply.*"
84 gdb_test
"python print (blist\[1\].hit_count)" \
85 "6" "Check breakpoint hit count @6"
86 gdb_test
"print result" \
87 " = 545" "Check expected variable result after 6 iterations"
89 # Test breakpoint is enabled and disabled correctly..
90 gdb_breakpoint
[gdb_get_line_number
"Break at add."]
91 gdb_continue_to_breakpoint
"Break at add 1" ".*Break at add.*"
92 gdb_test
"python print (blist\[1\].enabled)" \
93 "True" "Check breakpoint enabled."
94 gdb_py_test_silent_cmd
"python blist\[1\].enabled = False" \
95 "Set breakpoint disabled." 0
96 gdb_continue_to_breakpoint
"Break at add 2" ".*Break at add.*"
97 gdb_py_test_silent_cmd
"python blist\[1\].enabled = True" \
98 "Set breakpoint enabled." 0
99 gdb_continue_to_breakpoint
"Break at multiply after re-enable" \
100 ".*Break at multiply.*"
102 # Test other getters and setters.
103 gdb_py_test_silent_cmd
"python blist = gdb.breakpoints()" \
104 "Get Breakpoint List" 0
105 gdb_test
"python print (blist\[1\].thread)" \
106 "None" "Check breakpoint thread"
107 gdb_test
"python print (blist\[1\].type == gdb.BP_BREAKPOINT)" \
108 "True" "Check breakpoint type"
109 gdb_test
"python print (blist\[0\].number)" \
110 "1" "Check breakpoint number 0"
111 gdb_test
"python print (blist\[1\].number)" \
112 "2" "Check breakpoint number 1"
113 gdb_test
"python print (blist\[2\].number)" \
114 "3" "Check breakpoint number 2"
117 proc_with_prefix test_bkpt_deletion
{ } {
118 global srcfile testfile hex decimal
120 # Start with a fresh gdb.
121 clean_restart $
{testfile
}
123 if ![runto_main
] then {
127 # Test breakpoints are deleted correctly.
128 set deltst_location
[gdb_get_line_number
"Break at multiply."]
129 set end_location
[gdb_get_line_number
"Break at end."]
130 gdb_py_test_silent_cmd
"python dp1 = gdb.Breakpoint (\"$deltst_location\")" \
132 gdb_breakpoint
[gdb_get_line_number
"Break at end."]
133 gdb_py_test_silent_cmd
"python del_list = gdb.breakpoints()" \
134 "Get Breakpoint List" 0
135 gdb_test
"python print (len(del_list))" \
136 "3" "Number of breakpoints before delete"
137 gdb_continue_to_breakpoint
"Break at multiply." \
138 ".*$srcfile:$deltst_location.*"
139 gdb_py_test_silent_cmd
"python dp1.delete()" \
140 "Delete Breakpoint" 0
141 gdb_test
"python print (dp1.number)" \
142 "RuntimeError: Breakpoint 2 is invalid.*" \
143 "Check breakpoint invalidated"
144 gdb_py_test_silent_cmd
"python del_list = gdb.breakpoints()" \
145 "Get Breakpoint List" 0
146 gdb_test
"python print (len(del_list))" \
147 "2" "Number of breakpoints after delete"
148 gdb_continue_to_breakpoint
"Break at end." \
149 ".*$srcfile:$end_location.*"
152 proc_with_prefix test_bkpt_cond_and_cmds
{ } {
153 global srcfile testfile hex decimal
155 # Start with a fresh gdb.
156 clean_restart $
{testfile
}
158 if ![runto_main
] then {
162 # Test conditional setting.
163 set bp_location1
[gdb_get_line_number
"Break at multiply."]
164 gdb_py_test_silent_cmd
"python bp1 = gdb.Breakpoint (\"$bp_location1\")" \
166 gdb_continue_to_breakpoint
"Break at multiply" \
167 ".*Break at multiply.*"
168 gdb_py_test_silent_cmd
"python bp1.condition = \"i == 5\"" \
170 gdb_test
"python print (bp1.condition)" "i == 5" \
171 "Test conditional has been set"
172 gdb_continue_to_breakpoint
"Break at multiply @5" \
173 ".*Break at multiply.*"
175 "5" "Test conditional breakpoint stopped after five iterations"
176 gdb_py_test_silent_cmd
"python bp1.condition = None" \
178 gdb_test
"python print (bp1.condition)" \
179 "None" "Test conditional read"
180 gdb_continue_to_breakpoint
"Break at multiply @6" \
181 ".*Break at multiply.*"
183 "6" "Test breakpoint stopped after six iterations"
186 gdb_breakpoint
[gdb_get_line_number
"Break at add."]
187 set test
{commands $bpnum
}
188 gdb_test_multiple $test $test
{ -re
"\r\n>$" { pass $test } }
189 set test
{print
"Command for breakpoint has been executed."}
190 gdb_test_multiple $test $test
{ -re
"\r\n>$" { pass $test } }
191 set test
{print result
}
192 gdb_test_multiple $test $test
{ -re
"\r\n>$" { pass $test } }
195 gdb_py_test_silent_cmd
"python blist = gdb.breakpoints()" \
196 "Get Breakpoint List" 0
197 gdb_py_test_silent_cmd
"python last_bp = blist\[len(blist)-1\]" \
198 "Find last breakpoint" 0
199 gdb_test
"python print (last_bp.commands)" \
200 "print \"Command for breakpoint has been executed.\".*print result"
202 gdb_test_no_output
"python last_bp.commands = 'echo hi\\necho there'" \
204 # Note the length is
3 because the string ends in a
\n.
205 gdb_test
"python print (len(last_bp.commands.split('\\n')))" "3" \
206 "check number of lines in commands"
209 proc_with_prefix test_bkpt_invisible
{ } {
210 global srcfile testfile hex decimal
212 # Start with a fresh gdb.
213 clean_restart $
{testfile
}
215 if ![runto_main
] then {
220 set ibp_location
[gdb_get_line_number
"Break at multiply."]
221 gdb_py_test_silent_cmd
"python ibp = gdb.Breakpoint(\"$ibp_location\", internal=False)" \
222 "Set invisible breakpoint" 0
223 gdb_py_test_silent_cmd
"python ilist = gdb.breakpoints()" \
224 "Get Breakpoint List" 0
225 gdb_test
"python print (ilist\[0\])" \
226 "<gdb.Breakpoint object at $hex>" "Check invisible bp obj exists 1"
227 gdb_test
"python print (ilist\[0\].location)" \
228 "py-breakpoint\.c:$ibp_location*" "Check breakpoint location 1"
229 gdb_test
"python print (ilist\[0\].visible)" \
230 "True" "Check breakpoint visibility 1"
231 gdb_test
"info breakpoints" "py-breakpoint\.c:$ibp_location.*" \
232 "Check info breakpoints shows visible breakpoints"
234 gdb_py_test_silent_cmd
"python ibp = gdb.Breakpoint(\"$ibp_location\", internal=True)" \
235 "Set invisible breakpoint" 0
236 gdb_py_test_silent_cmd
"python ilist = gdb.breakpoints()" \
237 "Get Breakpoint List" 0
238 gdb_test
"python print (ilist\[0\])" \
239 "<gdb.Breakpoint object at $hex>" "Check invisible bp obj exists 2"
240 gdb_test
"python print (ilist\[0\].location)" \
241 "py-breakpoint\.c:$ibp_location*" "Check breakpoint location 2"
242 gdb_test
"python print (ilist\[0\].visible)" \
243 "False" "Check breakpoint visibility 2"
244 gdb_test
"info breakpoints" "No breakpoints or watchpoints.*" \
245 "Check info breakpoints does not show invisible breakpoints"
246 gdb_test
"maint info breakpoints" \
247 "py-breakpoint\.c:$ibp_location.*" \
248 "Check maint info breakpoints shows invisible breakpoints"
251 proc_with_prefix test_hardware_breakpoints
{ } {
252 global srcfile testfile hex decimal
254 # Skip these tests
if the HW does not support hardware breakpoints.
255 if { [skip_hw_breakpoint_tests
] } { return 0 }
257 # Start with a fresh gdb.
258 clean_restart $
{testfile
}
260 if ![runto_main
] then {
266 gdb_test
"python hbp1 = gdb.Breakpoint(\"add\", type=gdb.BP_HARDWARE_BREAKPOINT)" \
267 ".*Hardware assisted breakpoint ($decimal)+ at .*$srcfile, line ($decimal)+\." \
268 "Set hardware breakpoint"
269 gdb_test
"python print (gdb.breakpoints()\[0\].type == gdb.BP_HARDWARE_BREAKPOINT)" \
270 "True" "Check hardware breakpoint type"
271 gdb_test
"continue" \
272 ".*Breakpoint ($decimal)+, add.*" \
273 "Test hardware breakpoint stop"
276 proc_with_prefix test_watchpoints
{ } {
277 global srcfile testfile hex decimal
279 # Start with a fresh gdb.
280 clean_restart $
{testfile
}
282 # Disable hardware watchpoints
if necessary.
283 if [target_info
exists gdb
,no_hardware_watchpoints
] {
284 gdb_test_no_output
"set can-use-hw-watchpoints 0" ""
287 if ![runto_main
] then {
291 gdb_py_test_silent_cmd
"python wp1 = gdb.Breakpoint (\"result\", type=gdb.BP_WATCHPOINT, wp_class=gdb.WP_WRITE )" \
293 gdb_test
"python print (wp1.pending)" "False"
294 gdb_test
"continue" \
295 ".*\[Ww\]atchpoint.*result.*Old value = 0.*New value = 25.*main.*" \
296 "Test watchpoint write"
299 proc_with_prefix test_bkpt_internal
{ } {
300 global srcfile testfile hex decimal
302 # Start with a fresh gdb.
303 clean_restart $
{testfile
}
305 # Disable hardware watchpoints
if necessary.
306 if [target_info
exists gdb
,no_hardware_watchpoints
] {
307 gdb_test_no_output
"set can-use-hw-watchpoints 0" ""
309 if ![runto_main
] then {
313 gdb_py_test_silent_cmd
"python wp1 = gdb.Breakpoint (\"result\", type=gdb.BP_WATCHPOINT, wp_class=gdb.WP_WRITE, internal=True )" \
315 gdb_test
"info breakpoints" \
316 "No breakpoints or watchpoints.*" \
317 "Check info breakpoints does not show invisible breakpoints"
318 gdb_test
"maint info breakpoints" \
319 ".*watchpoint.*result.*" \
320 "Check maint info breakpoints shows invisible breakpoints"
321 gdb_test
"continue" \
322 ".*\[Ww\]atchpoint.*result.*Old value = 0.*New value = 25.*" \
323 "Test watchpoint write"
326 proc_with_prefix test_bkpt_eval_funcs
{ } {
327 global srcfile testfile hex decimal
329 # Start with a fresh gdb.
330 clean_restart $
{testfile
}
332 # Disable hardware watchpoints
if necessary.
333 if [target_info
exists gdb
,no_hardware_watchpoints
] {
334 gdb_test_no_output
"set can-use-hw-watchpoints 0" ""
336 if ![runto_main
] then {
341 gdb_test_multiline
"Sub-class a breakpoint" \
343 "class bp_eval (gdb.Breakpoint):" "" \
346 " def stop (self):" "" \
347 " self.count = self.count + 1" "" \
348 " self.inf_i = gdb.parse_and_eval(\"i\")" "" \
349 " if self.inf_i == 3:" "" \
354 gdb_test_multiline
"Sub-class a second breakpoint" \
356 "class bp_also_eval (gdb.Breakpoint):" "" \
358 " def stop (self):" "" \
359 " self.count = self.count + 1" "" \
360 " if self.count == 9:" "" \
365 gdb_test_multiline
"Sub-class a third breakpoint" \
367 "class basic (gdb.Breakpoint):" "" \
371 set bp_location2
[gdb_get_line_number
"Break at multiply."]
372 set end_location
[gdb_get_line_number
"Break at end."]
373 gdb_py_test_silent_cmd
"python eval_bp1 = bp_eval(\"$bp_location2\")" \
375 gdb_py_test_silent_cmd
"python also_eval_bp1 = bp_also_eval(\"$bp_location2\")" \
377 gdb_py_test_silent_cmd
"python never_eval_bp1 = bp_also_eval(\"$end_location\")" \
379 gdb_continue_to_breakpoint
"Break at multiply, i==3" \
380 ".*$srcfile:$bp_location2.*"
382 "3" "Check inferior value matches python accounting"
383 gdb_test
"python print (eval_bp1.inf_i)" \
384 "3" "Check python accounting matches inferior"
385 gdb_test
"python print (also_eval_bp1.count)" "4" \
386 "Check non firing same-location also_eval_bp1 function was also called at each stop."
387 gdb_test
"python print (eval_bp1.count)" "4" \
388 "Check non firing same-location eval_bp1 function was also called at each stop."
391 set cond_bp
[gdb_get_line_number
"Break at multiply."]
392 gdb_py_test_silent_cmd
"python eval_bp1 = bp_eval(\"$cond_bp\")" \
394 set test_cond
{cond $bpnum
}
395 gdb_test
"$test_cond \"foo==3\"" \
396 "Only one stop condition allowed. There is currently a Python.*" \
397 "Check you cannot add a CLI condition to a Python breakpoint that has defined stop"
398 gdb_py_test_silent_cmd
"python eval_bp2 = basic(\"$cond_bp\")" \
400 gdb_py_test_silent_cmd
"python eval_bp2.condition = \"1==1\"" \
402 gdb_test_multiline
"Construct an eval function" \
404 "def stop_func ():" "" \
408 gdb_test
"python eval_bp2.stop = stop_func" \
409 "RuntimeError: Only one stop condition allowed. There is currently a GDB.*" \
410 "assign stop function to a breakpoint that has a condition"
413 gdb_breakpoint
[gdb_get_line_number
"Break at multiply."]
414 gdb_py_test_silent_cmd
"python check_eval = bp_eval(\"$bp_location2\")" \
416 gdb_test
"python print (check_eval.count)" "0" \
417 "Test that evaluate function has not been yet executed (ie count = 0)"
418 gdb_continue_to_breakpoint
"Break at multiply, count==1" \
419 ".*$srcfile:$bp_location2.*"
420 gdb_test
"python print (check_eval.count)" "1" \
421 "Test that evaluate function is run when location also has normal bp"
423 gdb_test_multiline
"Sub-class a watchpoint" \
425 "class wp_eval (gdb.Breakpoint):" "" \
426 " def stop (self):" "" \
427 " self.result = gdb.parse_and_eval(\"result\")" "" \
428 " if self.result == 788:" "" \
434 gdb_py_test_silent_cmd
"python wp1 = wp_eval (\"result\", type=gdb.BP_WATCHPOINT, wp_class=gdb.WP_WRITE)" \
436 gdb_test
"continue" \
437 ".*\[Ww\]atchpoint.*result.*Old value =.*New value = 788.*" \
438 "Test watchpoint write"
439 gdb_test
"python print (never_eval_bp1.count)" "0" \
440 "Check that this unrelated breakpoints eval function was never called."
443 proc_with_prefix test_bkpt_temporary
{ } {
444 global srcfile testfile hex decimal
446 # Start with a fresh gdb.
447 clean_restart $
{testfile
}
449 if ![runto_main
] then {
454 gdb_test_multiline
"Sub-class and check temporary breakpoint" \
456 "class temp_bp (gdb.Breakpoint):" "" \
458 " def stop (self):" "" \
459 " self.count = self.count + 1" "" \
462 set ibp_location
[gdb_get_line_number
"Break at multiply."]
463 gdb_py_test_silent_cmd
"python ibp = temp_bp(\"$ibp_location\", temporary=True)" \
464 "Set temporary breakpoint" 0
465 gdb_test
"info breakpoints" \
466 "2.*breakpoint.*del.*py-breakpoint\.c:$ibp_location.*" \
467 "Check info breakpoints shows breakpoint with temporary status"
468 gdb_test
"python print (ibp.location)" "py-breakpoint\.c:$ibp_location*" \
469 "Check temporary breakpoint location"
470 gdb_test
"python print (ibp.temporary)" "True" \
471 "Check breakpoint temporary status"
472 gdb_continue_to_breakpoint
"Break at multiply." \
473 ".*$srcfile:$ibp_location.*"
474 gdb_test
"python print (ibp.count)" "1" \
475 "Check temporary stop callback executed before deletion."
476 gdb_test
"python print (ibp.temporary)" "RuntimeError: Breakpoint 2 is invalid.*" \
477 "Check temporary breakpoint is deleted after being hit"
478 gdb_test
"info breakpoints" "No breakpoints or watchpoints.*" \
479 "Check info breakpoints shows temporary breakpoint is deleted"
482 # Test address locations.
484 proc_with_prefix test_bkpt_address
{} {
485 global gdb_prompt decimal srcfile
487 #
Delete all breakpoints
490 gdb_test
"python gdb.Breakpoint(\"*main\")" \
491 ".*Breakpoint ($decimal)+ at .*$srcfile, line ($decimal)+\."
493 gdb_py_test_silent_cmd \
494 "python main_loc = gdb.parse_and_eval(\"main\").address" \
495 "eval address of main" 0
497 # Python
2 vs
3 ... Check `
int' first. If that fails, try `long'.
498 gdb_test_multiple
"python main_addr = int(main_loc)" "int value of main" {
499 -re
"Traceback.*$gdb_prompt $" {
500 gdb_test_no_output
"python main_addr = long(main_loc)" \
503 -re
"$gdb_prompt $" {
504 pass
"int value of main"
508 #
Include whitespace in the linespec to double
-check proper
509 # grokking of
argument to gdb.Breakpoint.
510 gdb_test
"python gdb.Breakpoint(\" *{}\".format(str(main_addr)))" \
511 ".*Breakpoint ($decimal)+ at .*$srcfile, line ($decimal)+\."
514 proc_with_prefix test_bkpt_pending
{} {
516 gdb_breakpoint
"nosuchfunction" allow-pending
517 gdb_test
"python print (gdb.breakpoints()\[0\].pending)" "True" \
518 "Check pending status of pending breakpoint"
521 # Helper proc to install an event listener
for a given breakpoint
522 # event.
NAME is the
name of the event to listen
for.
523 proc connect_event
{name} {
524 set lambda
"lambda x: note_event(\"$name\")"
525 gdb_test_no_output
"python gdb.events.$name.connect($lambda)" \
526 "install $name event listener"
529 # Helper proc to check that the most recently emitted breakpoint event
531 proc check_last_event
{expected
} {
532 gdb_test
"python print (last_bp_event)" $expected \
533 "check for $expected event"
536 proc_with_prefix test_bkpt_events
{} {
539 clean_restart $
{testfile
}
541 gdb_test_multiline
"Create event handler" \
543 "def note_event(arg):" "" \
544 " global last_bp_event" "" \
545 " last_bp_event = arg" "" \
547 gdb_test_no_output
"python last_bp_event = None"
549 connect_event breakpoint_created
550 connect_event breakpoint_modified
551 connect_event breakpoint_deleted
553 gdb_breakpoint
[gdb_get_line_number
"Break at add."]
554 check_last_event breakpoint_created
555 gdb_test_no_output
"disable 1"
556 check_last_event breakpoint_modified
557 gdb_test_no_output
"delete 1"
558 check_last_event breakpoint_deleted
561 proc_with_prefix test_bkpt_explicit_loc
{} {
562 global srcfile testfile
564 # Start with a fresh gdb.
565 clean_restart $
{testfile
}
567 if ![runto_main
] then {
573 set bp_location1
[gdb_get_line_number
"Break at multiply."]
574 set bp_location2
[gdb_get_line_number
"Break at add."]
576 gdb_py_test_silent_cmd
"python bp1 = gdb.Breakpoint (line=$bp_location1)" \
577 "set explicit breakpoint by line" 0
578 gdb_continue_to_breakpoint
"break at multiply for explicit line" \
579 ".*Break at multiply.*"
581 gdb_py_test_silent_cmd
"python bp1 = gdb.Breakpoint (line=\"+1\")" \
582 "set explicit breakpoint by relative line" 0
583 gdb_continue_to_breakpoint
"break at add for relative line" \
587 gdb_py_test_silent_cmd
"python bp1 = gdb.Breakpoint (line=\"-1\")" \
588 "set explicit breakpoint by relative negative line" 0
589 gdb_continue_to_breakpoint
"break at multiply for negative line" \
590 ".*Break at multiply.*"
593 gdb_test
"python bp1 = gdb.Breakpoint (line=bp1)" \
594 "RuntimeError: Line keyword should be an integer or a string.*" \
595 "set explicit breakpoint by invalid line type"
598 gdb_py_test_silent_cmd
"python bp1 = gdb.Breakpoint (function=\"add\")" \
599 "set explicit breakpoint by function" 0
600 gdb_continue_to_breakpoint
"break at function add for function" \
601 ".*Break at function add.*"
604 gdb_py_test_silent_cmd
"python bp1 = gdb.Breakpoint (source=\"$srcfile\", function=\"add\")" \
605 "set explicit breakpoint by source file and function" 0
606 gdb_continue_to_breakpoint
"break at function add for source and function" \
607 ".*Break at function add.*"
610 gdb_py_test_silent_cmd
"python bp1 = gdb.Breakpoint (source=\"$srcfile\", line=\"$bp_location2\")" \
611 "set explicit breakpoint by source file and line number" 0
612 gdb_continue_to_breakpoint
"break at add for source and line" \
616 gdb_py_test_silent_cmd
"python bp1 = gdb.Breakpoint (\"-source $srcfile -line $bp_location2\")" \
617 "set explicit breakpoint by source file and line number in spec" 0
618 gdb_continue_to_breakpoint
"break at add for source and line in spec" \
622 gdb_test
"python bp1 = gdb.Breakpoint (source=\"$srcfile\")" \
623 "RuntimeError: Specifying a source must also include a line, label or function.*" \
624 "set invalid explicit breakpoint by source only"
626 gdb_test
"python bp1 = gdb.Breakpoint (source=\"foo.c\", line=\"5\")" \
627 "No source file named foo.*" \
628 "set invalid explicit breakpoint by missing source and line"
629 gdb_test
"python bp1 = gdb.Breakpoint (source=\"$srcfile\", line=\"900\")" \
630 "No line 900 in file \"$srcfile\".*" \
631 "set invalid explicit breakpoint by source and invalid line"
632 gdb_test
"python bp1 = gdb.Breakpoint (function=\"blah\")" \
633 "Function \"blah\" not defined.*" \
634 "set invalid explicit breakpoint by missing function"
637 gdb_test
"catch throw" "Catchpoint .* \\(throw\\)"
638 gdb_test
"python print (gdb.breakpoints())" \
640 "catch throw is not a breakpoint"
643 proc_with_prefix test_bkpt_qualified
{} {
644 global decimal hex testfile
646 # Start with a fresh gdb.
647 clean_restart $
{testfile
}
649 set one_location_re
"Breakpoint $decimal at $hex:.*line $decimal."
650 set two_location_re
"Breakpoint $decimal at $hex:.*2 locations."
652 if ![runto_main
] then {
656 # Test the default value of
"qualified".
659 "python gdb.Breakpoint(\"multiply\")" \
661 "qualified implicitly false"
663 # Test qualified
=False.
666 "python gdb.Breakpoint(\"multiply\", qualified=False)" \
670 # Test qualified
=True.
673 "python gdb.Breakpoint(\"multiply\", qualified=True)" \
677 # Test qualified
=True with an explicit function.
680 "python gdb.Breakpoint(function=\"multiply\", qualified=True)" \
682 "qualified true and explicit"
684 # Test qualified
=False with an explicit function.
687 "python gdb.Breakpoint(function=\"multiply\", qualified=False)" \
689 "qualified false and explicit"
691 # Test
-q in the spec string.
694 "python gdb.Breakpoint(\"-q multiply\")" \
698 # Test
-q in the spec string with explicit location.
701 "python gdb.Breakpoint(\"-q -function multiply\")" \
703 "-q in spec string with explicit location"
705 # Test
-q in the spec string and qualified
=False
(-q should win
).
708 "python gdb.Breakpoint(\"-q multiply\", qualified=False)" \
710 "-q in spec string and qualified false"
713 proc_with_prefix test_bkpt_probe
{} {
714 global decimal hex testfile srcfile
716 if { [prepare_for_testing
"failed to prepare" ${testfile}-probes \
717 $
{srcfile
} {debug c
++ additional_flags
=-DUSE_PROBES
}] } {
721 if ![runto_main
] then {
726 "python gdb.Breakpoint(\"-probe test:result_updated\")" \
727 "Breakpoint $decimal at $hex" \
728 "-probe in spec string"
731 proc_with_prefix test_catchpoints
{} {
732 global srcfile testfile
733 global gdb_prompt decimal
735 # Start with a fresh gdb.
736 clean_restart $
{testfile
}
738 if ![runto_main
] then {
742 # Try to create a catchpoint
, currently this isn
't supported via
744 gdb_test "python gdb.Breakpoint (\"syscall\", type=gdb.BP_CATCHPOINT)" \
746 "gdb.error: BP_CATCHPOINT not supported" \
747 "Error while executing Python code\\."] \
748 "create a catchpoint via the api"
750 # Setup a catchpoint.
752 gdb_test_multiple "catch throw" "" {
753 -re "The feature \'catch throw\' is not supported.*\r\n$gdb_prompt $" {
754 unsupported "catch syscall isn't supported
"
757 -re
"Catchpoint ($decimal) \\(throw\\)\r\n$gdb_prompt $" {
758 set num $expect_out
(1,string
)
763 # Look
for the catchpoint in the breakpoint list.
764 gdb_test_multiline
"scan breakpoint list for BP_CATCHPOINT" \
766 "def scan_bp_list ():" "" \
767 " for b in gdb.breakpoints():" "" \
768 " if b.type == gdb.BP_CATCHPOINT:" "" \
769 " print(\"breakpoint #%d, type BP_CATCHPOINT\" % b.number)" "" \
771 gdb_test
"python scan_bp_list ()" \
772 "breakpoint #${num}, type BP_CATCHPOINT" \
773 "scan breakpoint for BP_CATCHPOINT"
775 # Arrange to print something when GDB stops
, then continue to the
776 # catchpoint and check we
get the expected event.
777 gdb_test_multiline
"setup stop event handler" \
779 "def stop_handler (event):" "" \
780 " if (isinstance (event, gdb.BreakpointEvent)" "" \
781 " and isinstance (event.breakpoint, gdb.Breakpoint)" "" \
782 " and event.breakpoint.type == gdb.BP_CATCHPOINT):" "" \
783 " print (\"Stopped at catchpoint event: %d\" % event.breakpoint.number)" "" \
785 "python gdb.events.stop.connect (stop_handler)" ""
786 gdb_test
"continue" "Stopped at catchpoint event: ${num}"
789 # Test auto
-disable is effective when notifying breakpoint_modified.
791 proc_with_prefix test_bkpt_auto_disable
{ } {
792 global srcfile testfile hex decimal
794 # Start with a fresh gdb.
795 clean_restart $
{testfile
}
797 if ![runto_main
] then {
802 set mult_line
[gdb_get_line_number
"Break at multiply."]
803 gdb_breakpoint $
{mult_line
}
804 gdb_test_no_output
"enable count 1 2" "one shot enable"
805 # Python
2 doesn
't support print in lambda function, so use a named
807 gdb_test_multiline "Define print_bp_enabled" \
809 "def print_bp_enabled (bp):" "" \
810 " print (bp.enabled)" "" \
813 "python gdb.events.breakpoint_modified.connect(print_bp_enabled)" \
814 "trap breakpoint_modified event"
815 gdb_test "continue" "False.*" "auto-disabling after enable count reached"
820 test_bkpt_cond_and_cmds
822 test_hardware_breakpoints
831 test_bkpt_explicit_loc
834 test_bkpt_auto_disable