Home | History | Annotate | Line # | Download | only in gdb.dap
pause.exp revision 1.1
      1  1.1  christos # Copyright 2023-2024 Free Software Foundation, Inc.
      2  1.1  christos 
      3  1.1  christos # This program is free software; you can redistribute it and/or modify
      4  1.1  christos # it under the terms of the GNU General Public License as published by
      5  1.1  christos # the Free Software Foundation; either version 3 of the License, or
      6  1.1  christos # (at your option) any later version.
      7  1.1  christos #
      8  1.1  christos # This program is distributed in the hope that it will be useful,
      9  1.1  christos # but WITHOUT ANY WARRANTY; without even the implied warranty of
     10  1.1  christos # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     11  1.1  christos # GNU General Public License for more details.
     12  1.1  christos #
     13  1.1  christos # You should have received a copy of the GNU General Public License
     14  1.1  christos # along with this program.  If not, see <http://www.gnu.org/licenses/>.
     15  1.1  christos 
     16  1.1  christos # Test "pause" in DAP.
     17  1.1  christos 
     18  1.1  christos require allow_dap_tests
     19  1.1  christos 
     20  1.1  christos load_lib dap-support.exp
     21  1.1  christos 
     22  1.1  christos standard_testfile
     23  1.1  christos 
     24  1.1  christos if {[build_executable ${testfile}.exp $testfile $srcfile] == -1} {
     25  1.1  christos     return
     26  1.1  christos }
     27  1.1  christos 
     28  1.1  christos if {[dap_initialize] == ""} {
     29  1.1  christos     return
     30  1.1  christos }
     31  1.1  christos 
     32  1.1  christos # Set a conditional breakpoint that will never fire.  This is done to
     33  1.1  christos # test the state-tracking in events -- an inferior call from a
     34  1.1  christos # breakpoint condition should not cause any sort of stop or continue
     35  1.1  christos # events.
     36  1.1  christos set line [gdb_get_line_number "STOP"]
     37  1.1  christos dap_check_request_and_response "set conditional breakpoint" \
     38  1.1  christos     setBreakpoints \
     39  1.1  christos     [format {o source [o path [%s]] \
     40  1.1  christos 		 breakpoints [a [o line [i %d] \
     41  1.1  christos 				     condition [s "return_false()"]]]} \
     42  1.1  christos 	 [list s $srcfile] $line]
     43  1.1  christos 
     44  1.1  christos dap_check_request_and_response "configurationDone" configurationDone
     45  1.1  christos 
     46  1.1  christos if {[dap_launch $testfile] == ""} {
     47  1.1  christos     return
     48  1.1  christos }
     49  1.1  christos dap_wait_for_event_and_check "process event generated" process \
     50  1.1  christos     "body startMethod" process
     51  1.1  christos dap_wait_for_event_and_check "inferior started" thread "body reason" started
     52  1.1  christos 
     53  1.1  christos set resp [lindex [dap_request_and_response evaluate {o expression [s 23]}] \
     54  1.1  christos 	      0]
     55  1.1  christos gdb_assert {[dict get $resp success] == "false"} \
     56  1.1  christos     "evaluate failed while inferior executing"
     57  1.1  christos gdb_assert {[dict get $resp message] == "notStopped"} \
     58  1.1  christos     "evaluate issued notStopped"
     59  1.1  christos 
     60  1.1  christos dap_check_request_and_response pause pause \
     61  1.1  christos     {o threadId [i 1]}
     62  1.1  christos 
     63  1.1  christos dap_wait_for_event_and_check "stopped by pause" stopped \
     64  1.1  christos     "body reason" pause
     65  1.1  christos 
     66  1.1  christos set result [dap_request_and_response evaluate {o expression [s do_nothing()]}]
     67  1.1  christos gdb_assert {[dict get [lindex $result 0] body result] == 91} \
     68  1.1  christos     "check result of evaluation"
     69  1.1  christos 
     70  1.1  christos set seen fail
     71  1.1  christos foreach event [lindex $result 1] {
     72  1.1  christos     if {[dict get $event type] != "event"} {
     73  1.1  christos 	continue
     74  1.1  christos     }
     75  1.1  christos     if {[dict get $event event] == "continued"} {
     76  1.1  christos 	set seen pass
     77  1.1  christos 	break
     78  1.1  christos     }
     79  1.1  christos }
     80  1.1  christos gdb_assert {$seen == "pass"} "continue event from inferior call"
     81  1.1  christos 
     82  1.1  christos #
     83  1.1  christos # Test that a repl evaluation that causes a continue can be canceled.
     84  1.1  christos #
     85  1.1  christos 
     86  1.1  christos set cont_id [dap_send_request evaluate \
     87  1.1  christos 		 {o expression [s continue] context [s repl]}]
     88  1.1  christos dap_wait_for_event_and_check "continued" continued
     89  1.1  christos 
     90  1.1  christos set cancel_id [dap_send_request cancel \
     91  1.1  christos 		   [format {o requestId [i %d]} $cont_id]]
     92  1.1  christos 
     93  1.1  christos # The stop event will come before any responses to the requests.
     94  1.1  christos dap_wait_for_event_and_check "stopped by cancel" stopped
     95  1.1  christos 
     96  1.1  christos # Now we can wait for the 'continue' request to complete, and then the
     97  1.1  christos # 'cancel' request.
     98  1.1  christos dap_read_response evaluate $cont_id
     99  1.1  christos dap_read_response cancel $cancel_id
    100  1.1  christos 
    101  1.1  christos #
    102  1.1  christos # Test that a repl evaluation of a long-running gdb command (that does
    103  1.1  christos # not continue the inferior) can be canceled.
    104  1.1  christos #
    105  1.1  christos 
    106  1.1  christos proc write_file {suffix contents} {
    107  1.1  christos     global testfile
    108  1.1  christos 
    109  1.1  christos     set gdbfile [standard_output_file ${testfile}.$suffix]
    110  1.1  christos     set ofd [open $gdbfile w]
    111  1.1  christos     puts $ofd $contents
    112  1.1  christos     close $ofd
    113  1.1  christos     return $gdbfile
    114  1.1  christos }
    115  1.1  christos 
    116  1.1  christos set gdbfile [write_file gdb "set \$x = 0\nwhile 1\nset \$x = \$x + 1\nend"]
    117  1.1  christos set cont_id [dap_send_request evaluate \
    118  1.1  christos 		 [format {o expression [s "source %s"] context [s repl]} \
    119  1.1  christos 		      $gdbfile]]
    120  1.1  christos 
    121  1.1  christos # Wait a little to try to ensure the command is running.
    122  1.1  christos sleep 0.2
    123  1.1  christos set cancel_id [dap_send_request cancel \
    124  1.1  christos 		   [format {o requestId [i %d]} $cont_id]]
    125  1.1  christos 
    126  1.1  christos set info [lindex [dap_read_response evaluate $cont_id] 0]
    127  1.1  christos gdb_assert {[dict get $info success] == "false"} "gdb command failed"
    128  1.1  christos gdb_assert {[dict get $info message] == "cancelled"} "gdb command canceled"
    129  1.1  christos 
    130  1.1  christos dap_read_response cancel $cancel_id
    131  1.1  christos 
    132  1.1  christos #
    133  1.1  christos # Test that a repl evaluation of a long-running Python command (that
    134  1.1  christos # does not continue the inferior) can be canceled.
    135  1.1  christos #
    136  1.1  christos 
    137  1.1  christos set gdbfile [write_file py "while True:\n  pass"]
    138  1.1  christos set cont_id [dap_send_request evaluate \
    139  1.1  christos 		 [format {o expression [s "source %s"] context [s repl]} \
    140  1.1  christos 		      $gdbfile]]
    141  1.1  christos 
    142  1.1  christos # Wait a little to try to ensure the command is running.
    143  1.1  christos sleep 0.2
    144  1.1  christos set cancel_id [dap_send_request cancel \
    145  1.1  christos 		   [format {o requestId [i %d]} $cont_id]]
    146  1.1  christos 
    147  1.1  christos set info [lindex [dap_read_response evaluate $cont_id] 0]
    148  1.1  christos gdb_assert {[dict get $info success] == "false"} "python command failed"
    149  1.1  christos gdb_assert {[dict get $info message] == "cancelled"} "python command canceled"
    150  1.1  christos 
    151  1.1  christos dap_read_response cancel $cancel_id
    152  1.1  christos 
    153  1.1  christos dap_shutdown
    154