
The "python" command (and the Python implementation of the gdb "source" command) does not handle Python exceptions in the same way as other gdb-facing Python code. In particular, exceptions are turned into a generic error rather than being routed through gdbpy_handle_exception, which takes care of converting to 'quit' as appropriate. I think this was done this way because PyRun_SimpleFile and friends do not propagate the Python exception -- they simply indicate that one occurred. This patch reimplements these functions to respect the general gdb convention here. As a bonus, some Windows-specific code can be removed, as can the _execute_file function. The bulk of this change is tweaking the test suite to match the new way that exceptions are displayed. These changes are largely uninteresting. However, it's worth pointing out the py-error.exp change. Here, the failure changes because the test changes the host charset to something that isn't supported by Python. This then results in a weird error in the new setup. Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=31354 Acked-By: Tom de Vries <tdevries@suse.de> Reviewed-By: Eli Zaretskii <eliz@gnu.org>
65 lines
2 KiB
Text
65 lines
2 KiB
Text
# Copyright (C) 2020-2024 Free Software Foundation, Inc.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
# Test a TUI window implemented in Python.
|
|
|
|
load_lib gdb-python.exp
|
|
require allow_python_tests allow_tui_tests
|
|
tuiterm_env
|
|
|
|
# This test doesn't care about the inferior.
|
|
standard_testfile py-arch.c
|
|
|
|
if {[build_executable "failed to prepare" ${testfile} ${srcfile}] == -1} {
|
|
return -1
|
|
}
|
|
|
|
clean_restart
|
|
|
|
Term::clean_restart 24 80 $testfile
|
|
|
|
set remote_python_file [gdb_remote_download host \
|
|
${srcdir}/${subdir}/${testfile}.py]
|
|
gdb_test_no_output "source ${remote_python_file}" \
|
|
"source ${testfile}.py"
|
|
|
|
gdb_test_no_output "tui new-layout test test 1 status 0 cmd 1"
|
|
gdb_test_no_output "tui new-layout fail fail 1 status 0 cmd 1"
|
|
|
|
if {![Term::enter_tui]} {
|
|
unsupported "TUI not supported"
|
|
return
|
|
}
|
|
|
|
Term::command "layout test"
|
|
Term::check_contents "test title" \
|
|
"This Is The Title"
|
|
Term::check_contents "Window display" "Test: 0"
|
|
|
|
Term::command "python delete_window_title ()"
|
|
Term::check_contents "error message after trying to delete title" \
|
|
"TypeError.*: Cannot delete \"title\" attribute\\."
|
|
Term::check_contents "title is unchanged" \
|
|
"This Is The Title"
|
|
|
|
Term::command "python change_window_title ()"
|
|
Term::check_contents "test new title" \
|
|
"New Title"
|
|
|
|
Term::resize 51 51
|
|
# Remember that a resize request actually does two resizes...
|
|
Term::check_contents "Window was updated" "Test: 2"
|
|
|
|
Term::command "layout fail"
|