mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-24 12:35:55 +08:00
203 lines
8.2 KiB
Plaintext
203 lines
8.2 KiB
Plaintext
|
The highest priority item is not on this list: Fix bugs in the
|
|||
|
existing testsuite, fix the GDB/compiler/shell/etc bugs which it
|
|||
|
detects (particularly when they are hard to XFAIL), make it run
|
|||
|
reliably without unexpected failures on the "standard" machines, etc.
|
|||
|
This list exists largely as "tests we can add when we are ready to
|
|||
|
risk destabilizing it again".
|
|||
|
|
|||
|
There are some tests which are only run on some platforms because they
|
|||
|
have not been tested on more platforms. Enable them and fix any
|
|||
|
problems. A partial list: recurse.exp, watchpoint.exp
|
|||
|
(test_watchpoint_triggered_in_syscall, test_complex_watchpoint).
|
|||
|
|
|||
|
Test printing of structures passed by value, for the 7th, 8th, and 9th
|
|||
|
arguments (PR 1714). Test printing structure arguments of
|
|||
|
2,4,6,8,12,16,and 20 bytes. Same for structure return of all those
|
|||
|
sizes ("return", "finish", and call function).
|
|||
|
|
|||
|
Get crossload tests to use --enable-targets and reenable them.
|
|||
|
|
|||
|
corefile.exp:
|
|||
|
Test ability to run program when there is a core target, then go
|
|||
|
back to the core file when the program exits.
|
|||
|
|
|||
|
Test handling of floating point variables
|
|||
|
1. float, double, or long double
|
|||
|
2. in register or saved register or memory. Also the case where a
|
|||
|
double is in two float registers and only one of them is saved.
|
|||
|
3. print them or set them
|
|||
|
4. (Alpha) integer (32 or 64 bit) in floating point register.
|
|||
|
|
|||
|
Print registers--"p $r5", "p sizeof ($r5)". Test that they print
|
|||
|
appropriately (integer registers in decimal, registers which always
|
|||
|
contain addresses (pc, probably sp and fp, maybe others) in hex,
|
|||
|
floating point).
|
|||
|
|
|||
|
Test completer. Test that it completes a variety of things correctly
|
|||
|
(see the list of test cases in main.c in the gdb source). Test TAB,
|
|||
|
M-?, and the "complete" command.
|
|||
|
|
|||
|
Test "info line" with all kinds of linespecs. Test that the last line
|
|||
|
of the file works right.
|
|||
|
|
|||
|
weird.exp--test that unrecognized cross-reference types or
|
|||
|
unrecognized visibility or virtual characters get skipped properly
|
|||
|
(see stabs.texinfo).
|
|||
|
|
|||
|
Test C++ nested types (especially if PR 1954 is fixed; even if not
|
|||
|
*some* things already should work even in the presence of nested
|
|||
|
types). Test classes nested more than 9 levels deep (g++ mangles
|
|||
|
these differently) (both a demangle test and some tests which also
|
|||
|
test the compiler). Test calling a method of a class nested more than
|
|||
|
9 levels (for gdb_mangle_name and demangling).
|
|||
|
|
|||
|
Test static member functions (C++). Test that "ptype" shows them
|
|||
|
correctly, both before and after they have been converted from stub
|
|||
|
methods. Test that we can call them.
|
|||
|
|
|||
|
Test printing complicated types, including functions, pointers to
|
|||
|
arrays of pointers of functions, functions which return pointers to
|
|||
|
functions, etc.
|
|||
|
|
|||
|
printcmd.exp--test printing enum values. Test printing an enum
|
|||
|
variable whose value is out of range. Test "p (int)enum_var", "p/x
|
|||
|
enum_var". Test that in something like "enum {FOO, LAST_THING=FOO}"
|
|||
|
we print FOO, not LAST_THING.
|
|||
|
|
|||
|
Test GDB expressions--test all operators (and overloaded operators for
|
|||
|
C++). Test integer constants which are signed or unsigned int, long,
|
|||
|
or long long. Test detection of overflow of an integer constant.
|
|||
|
Here are a few integer constants to test (test they get the right
|
|||
|
types): 5, 5LL, 5LuL, 5L6u (invalid), 5LU. Maybe things like
|
|||
|
0x12345678, 0x87654321, etc., but their types depend on sizes of int,
|
|||
|
long, etc.
|
|||
|
|
|||
|
Test that printing const-qualified versions of various types works.
|
|||
|
In particular, on the sparc and probably other machines, "double" is
|
|||
|
handled differently from most types because it requires more alignment
|
|||
|
and thus goes in a different section (there is a gcc 2.4.5 bug with
|
|||
|
"const double" on sparc).
|
|||
|
|
|||
|
Test that GDB's "source" command works and that things work if stdin
|
|||
|
is redirected (to a file or a pipe). Test user defined command. Run
|
|||
|
an inferior each of these ways (to test that inflow.c works). Test
|
|||
|
that GDB works if the last line of stdin or a source'd file lacks a
|
|||
|
newline.
|
|||
|
|
|||
|
Test that unmatched single quotes produce error messages, both in
|
|||
|
expressions and linespecs.
|
|||
|
|
|||
|
Test "cd". "foo/bar/.." should get simplified to "foo". "/../.."
|
|||
|
should not get simplified (for Mach). "/.." should not get simplified
|
|||
|
(for other networked OSes; POSIX.1 section B.2.3.7). All these
|
|||
|
examples should continue to work with trailing slashes.
|
|||
|
|
|||
|
Test scoping; here is a start
|
|||
|
1 int i=2;
|
|||
|
2 int j=3;
|
|||
|
3 main()
|
|||
|
4 {
|
|||
|
5 int i;
|
|||
|
6 for (i=600; i>0; i--)
|
|||
|
7 print_line(i);
|
|||
|
8 }
|
|||
|
9
|
|||
|
10 print_line(i)
|
|||
|
11 int i;
|
|||
|
12 {
|
|||
|
13 h();
|
|||
|
14 printf("%d\n",i);
|
|||
|
15 }
|
|||
|
16
|
|||
|
17 h()
|
|||
|
18 {
|
|||
|
19 printf("In h...");
|
|||
|
20 }
|
|||
|
Set a breakpoint in h, and print i, print_line::i, and main::i. Set a
|
|||
|
breakpoint in main (or don't run the program), and test that
|
|||
|
print_line::i is an error. But if i were static, "p main::i" should
|
|||
|
work even if the program is not being run.
|
|||
|
|
|||
|
Write a test for the reentracy bug with rs6000_struct_return_address
|
|||
|
in rs6000-tdep.c.
|
|||
|
|
|||
|
Test "return" from dummy frames. Test "return" from non-innermost
|
|||
|
frame. Test that "return" from a non-innermost frame restores
|
|||
|
registers which are saved not in that frame but in a frame more inner
|
|||
|
(I believe this currently works on few if any architectures).
|
|||
|
|
|||
|
FORTRAN common blocks (a.out and xcoff--weird.exp has the start of
|
|||
|
one but it is not quite right as of 19 Nov 1993).
|
|||
|
|
|||
|
Test that "x" command sets $_ and $__. Test $_ in general.
|
|||
|
|
|||
|
Test that "p/a" works when given addresses in text, data, and bss
|
|||
|
segments. Test that it works if program is compiled with or without
|
|||
|
-g. Test that it works if preceding symbol is static or if it is
|
|||
|
extern.
|
|||
|
|
|||
|
Given `char abc[] = "abc\0def";' test "x/s abc" followed by "x/s"
|
|||
|
(should display "abc" followed by "def"). Test this works with no
|
|||
|
error message even if this is the last thing in the section (tests
|
|||
|
that val_print_string ignores an error if the error occurs after the
|
|||
|
'\0').
|
|||
|
|
|||
|
Test ability to process NMAGIC a.out files.
|
|||
|
|
|||
|
Test shared libraries: "next" over printf, "step" into a function in
|
|||
|
a shared library which has line number info, breakpoint in a function
|
|||
|
in a shared library (either before or after the program is run and the
|
|||
|
shared libraries are loaded--also maybe write a test where the PLT
|
|||
|
will be in an unloaded state even though the shared library is loaded).
|
|||
|
|
|||
|
If there are two breakpoints in the same place, and exactly one of
|
|||
|
them has its condition true, test that the correct breakpoint gets
|
|||
|
printed.
|
|||
|
|
|||
|
Test "jump" including jump to a breakpoint (the latter will need an
|
|||
|
xfail for UDI and probably VxWorks (PR 1786 for vxworks; PR 2416
|
|||
|
contains some info for 29k).
|
|||
|
|
|||
|
Set a watchpoint on a local variable (to be interesting, make a few
|
|||
|
calls, to be more interesting, make a recursive call). Test that it
|
|||
|
gets disabled when leaving that scope.
|
|||
|
|
|||
|
Test calling a function, hitting a breakpoint in the called function,
|
|||
|
calling another function, and hitting a breakpoint. Test backtrace
|
|||
|
works in the presence of multiple dummy frames. Test that "continue"
|
|||
|
will get you out of the inner called function, and "continue" again
|
|||
|
will get you back to where you were when you called the first one.
|
|||
|
|
|||
|
Test special longjmp handling in wait_for_inferior (need to figure out
|
|||
|
in detail what the proper behavior in each case is). Test longjmp to
|
|||
|
a place where there is a breakpoint (such that
|
|||
|
BPSTAT_WHAT_CLEAR_LONGJMP_RESUME_SINGLE happens). In general, test
|
|||
|
interactions between longjmp and watchpoints, breakpoints, stepping,
|
|||
|
call function, etc.
|
|||
|
|
|||
|
Test jumping right past a breakpoint (the case where wait_for_inferior
|
|||
|
passes not_a_breakpoint to bpstat_stop_status). Might already be
|
|||
|
tested by some of the sun3 tests. Probably want a .s test to avoid
|
|||
|
compiler dependencies.
|
|||
|
|
|||
|
Test more obscure wait_for_inferior cases, expanding on the tests in
|
|||
|
watchpoint.exp, signals.exp, etc.
|
|||
|
|
|||
|
Test stepping into functions which are one line long and functions
|
|||
|
which are on line 1 of the source file. (there is a class of bugs in
|
|||
|
which gdb doesn't find the line number information, and thus doesn't
|
|||
|
step into the function).
|
|||
|
|
|||
|
Test that prologue recognition, backtrace, printing locals, etc.,
|
|||
|
still work in the presence of large frames (the point being that at
|
|||
|
some point immediate fields in RISC instructions will overflow and
|
|||
|
prologues will need to look different. For sparc, the immediate field
|
|||
|
is 13 bits (signed), so I believe the threshold would be 4K bytes in a
|
|||
|
frame).
|
|||
|
|
|||
|
|
|||
|
(this is for editing this file with GNU emacs)
|
|||
|
Local Variables:
|
|||
|
mode: text
|
|||
|
End:
|