aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.base
diff options
context:
space:
mode:
authorJim Kingdon <jkingdon@engr.sgi.com>1995-01-17 16:22:23 +0000
committerJim Kingdon <jkingdon@engr.sgi.com>1995-01-17 16:22:23 +0000
commit29f25f6f6974faf467f8545941cf4d4b8dfe0188 (patch)
treef0118b89e146ee896239d017ce84a5fa9d61edb4 /gdb/testsuite/gdb.base
parent3fb93d868b03604d3cb5ef6433f2eabf98abcd11 (diff)
downloadgdb-29f25f6f6974faf467f8545941cf4d4b8dfe0188.zip
gdb-29f25f6f6974faf467f8545941cf4d4b8dfe0188.tar.gz
gdb-29f25f6f6974faf467f8545941cf4d4b8dfe0188.tar.bz2
* gdb.base/nodebug.exp: Add tests to check that "print", "whatis"
and "ptype" work on variables in files compiled without -g. Replaces commented out "maint print msymbol" tests.
Diffstat (limited to 'gdb/testsuite/gdb.base')
-rw-r--r--gdb/testsuite/gdb.base/nodebug.exp70
1 files changed, 70 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.base/nodebug.exp b/gdb/testsuite/gdb.base/nodebug.exp
new file mode 100644
index 0000000..52f6bd1
--- /dev/null
+++ b/gdb/testsuite/gdb.base/nodebug.exp
@@ -0,0 +1,70 @@
+# Test that things still (sort of) work when compiled without -g.
+# In gdb.t10 because it is related to symbol-reading, and so are the crossload
+# tests.
+
+if $tracelevel then {
+ strace $tracelevel
+}
+
+set prms_id 0
+set bug_id 0
+
+set binfile $objdir/$subdir/nodebug
+
+if ![file exists $binfile] then {
+ perror "$binfile does not exist."
+ return 0
+} else {
+ gdb_reinitialize_dir $srcdir/$subdir
+ gdb_load $binfile
+
+ if [runto inner] then {
+
+ # Expect to find global/local symbols in each of text/data/bss.
+
+ # The exact format for some of this output is not necessarily
+ # ideal, particularly interpreting "p top" requires a fair bit of
+ # savvy about gdb's workings and the meaning of the "{}"
+ # construct. So the details maybe could be tweaked. But the
+ # basic purpose should be maintained, which is (a) users should be
+ # able to interact with these variables with some care (they have
+ # to know how to interpret them according to their real type,
+ # since gdb doesn't know the type), but (b) users should be able
+ # to detect that gdb does not know the type, rather than just
+ # being told they are ints or functions returning int like old
+ # versions of gdb used to do.
+
+ gdb_test "p top" "{<text variable without -g>} \[0-9a-fx]* <top>"
+ gdb_test "whatis top" "<text variable without -g>"
+ gdb_test "ptype top" "int \\(\\)"
+
+ gdb_test "p middle" "{<text variable without -g>} \[0-9a-fx]* <middle>"
+ gdb_test "whatis middle" "<text variable without -g>"
+ gdb_test "ptype middle" "int \\(\\)"
+
+ gdb_test "p dataglobal" "= 3"
+ gdb_test "whatis dataglobal" "<data variable without -g>"
+ gdb_test "ptype dataglobal" "<data variable without -g>"
+
+ gdb_test "p datalocal" "= 4"
+ gdb_test "whatis datalocal" "<data variable without -g>"
+ gdb_test "ptype datalocal" "<data variable without -g>"
+
+ gdb_test "p bssglobal" "= 0"
+ gdb_test "whatis bssglobal" "<data variable without -g>"
+ gdb_test "ptype bssglobal" "<data variable without -g>"
+
+ gdb_test "p bsslocal" "= 0"
+ gdb_test "whatis bsslocal" "<data variable without -g>"
+ gdb_test "ptype bsslocal" "<data variable without -g>"
+
+ gdb_test "backtrace" "#0.*inner.*#1.*middle.*#2.*top.*#3.*main"
+ # Or if that doesn't work, at least hope for the external symbols
+ gdb_test "backtrace" "#0.*inner.*#1.*#2.*top.*#3.*main"
+ # Now, try that we can give names of file-local symbols which happen
+ # to be unique, and have it still work
+ if [runto middle] then {
+ gdb_test "backtrace" "#0.*middle.*#1.*top.*#2.*main"
+ }
+ }
+}