[PATCH] [gdb/testsuite] Handle missing curses in gdb.python/py-missing-debug.exp

Andrew Burgess aburgess@redhat.com
Sun Sep 8 20:38:39 GMT 2024


Tom de Vries <tdevries@suse.de> writes:

> On a system with python 3.6, module gdb.missing_debug imports module curses,
> so when running test-case gdb.python/py-missing-debug.exp on a system without
> that module installed, we run into:
> ...
> (gdb) source py-missing-debug.py^M
> Python Exception <class 'ImportError'>: Module 'curses' is not installed.^M
> Use:^M
>   sudo zypper install python36-curses^M
> to install it.^M
> Error occurred in Python: Module 'curses' is not installed.^M
> Use:^M
>   sudo zypper install python36-curses^M
> to install it.^M
> (gdb) FAIL: gdb.python/py-missing-debug.exp: source python script

Do you know where the curses include is coming from?

The py-missing-debug.py imports 'os' for os.rename and 'enum' for 'Enum'
class.  I'm guessing one of these, (maybe 'os' ?) is pulling in curses,
but maybe there's something better we could use other than os.rename
which would avoid this issue?

If is 'os' that is pulling in 'curses', doesn't this feel like either
the system was broken anyway, or the package dependencies are broken?

Just curious to understand this better as I was a little surprised to
see that curses was a dependency of this test.

Thanks,
Andrew


> ...
>
> Fix this by issuing UNSUPPORTED instead, and bailing out.
>
> Tested on x86_64-linux.
>
> PR testsuite/31576
> Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=31576
> ---
>  gdb/testsuite/gdb.python/py-missing-debug.exp | 17 +++++++++++++++--
>  1 file changed, 15 insertions(+), 2 deletions(-)
>
> diff --git a/gdb/testsuite/gdb.python/py-missing-debug.exp b/gdb/testsuite/gdb.python/py-missing-debug.exp
> index dfc0a467b2a..9d853d3a311 100644
> --- a/gdb/testsuite/gdb.python/py-missing-debug.exp
> +++ b/gdb/testsuite/gdb.python/py-missing-debug.exp
> @@ -58,8 +58,21 @@ with_test_prefix "initial checks" {
>  }
>  
>  # Load the Python script into GDB.
> -gdb_test "source $remote_python_file" "^Success" \
> -    "source python script"
> +set python_script_loaded 0
> +set re_no_curses [string_to_regexp "Module 'curses' is not installed."]
> +gdb_test_multiple "source $remote_python_file" "source python script" {
> +    -re -wrap $re_no_curses.* {
> +	unsupported $gdb_test_name
> +    }
> +    -re -wrap "^Success" {
> +	set python_script_loaded 1
> +	pass $gdb_test_name
> +    }
> +}
> +
> +if { ! $python_script_loaded } {
> +    return
> +}
>  
>  # Setup the separate debug info directory.  This isn't actually needed until
>  # some of the later tests, but might as well get this done now.
>
> base-commit: 4723415cda09b09dbac743f30f877355a49fdee2
> -- 
> 2.35.3



More information about the Gdb-patches mailing list