aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.python/py-warning.exp
blob: 6b26a4ea26eea8663985a0266d0f1a1a8963206f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# Copyright (C) 2025 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 the gdb.warning() function.

load_lib gdb-python.exp

require allow_python_tests

clean_restart

# Basic usage.
gdb_test "python gdb.warning(\"some text\")" \
    "warning: some text"

# Basic usage with named argument.
gdb_test "python gdb.warning(text=\"a warning message\")" \
    "warning: a warning message"

# Make sure GDB prints format specifiers correctly.
gdb_test "python gdb.warning(\"%s %d %p\")" \
    "warning: %s %d %p"

# Empty string gives an error.
gdb_test "python gdb.warning(\"\")" \
    [multi_line \
	 "Python Exception <class 'ValueError'>: Empty text string passed to gdb\\.warning" \
	 "Error occurred in Python: Empty text string passed to gdb\\.warning"]

# Missing argument gives an error.
set re1 \
    [multi_line \
	 [string_to_regexp \
	      [concat \
		   "Python Exception <class 'TypeError'>:" \
		   "function missing required argument 'text' (pos 1)"]] \
	 [string_to_regexp \
	      [concat \
		   "Error occurred in Python:" \
		   "function missing required argument 'text' (pos 1)"]]]
set re2 \
    [multi_line \
	 [string_to_regexp \
	      [concat \
		   "Python Exception <class 'TypeError'>:" \
		   "Required argument 'text' (pos 1) not found"]] \
	 [string_to_regexp \
	      [concat \
		   "Error occurred in Python:" \
		   "Required argument 'text' (pos 1) not found"]]]
gdb_test "python gdb.warning()" $re1|$re2