aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2012-01-16 17:31:25 +0000
committerPedro Alves <palves@redhat.com>2012-01-16 17:31:25 +0000
commitabcc497831b4dbb2e6cb16ca38baec1e68c93a6f (patch)
treee01423dd712dedaecd8ac2a2a172b06dd004a8b4
parent97ccebe869a69550b5a89a59b99955fb783f2b81 (diff)
downloadgdb-abcc497831b4dbb2e6cb16ca38baec1e68c93a6f.zip
gdb-abcc497831b4dbb2e6cb16ca38baec1e68c93a6f.tar.gz
gdb-abcc497831b4dbb2e6cb16ca38baec1e68c93a6f.tar.bz2
2012-01-16 Pedro Alves <palves@redhat.com>
* lib/gdb.exp (banned_procedures): New variable. (banned_variables_traced): Rename to ... (banned_traced): ... this. (gdb_init): Also trace banned procedures. (gdb_finish): Also untrace banned procedures.
-rw-r--r--gdb/testsuite/ChangeLog8
-rw-r--r--gdb/testsuite/lib/gdb.exp34
2 files changed, 33 insertions, 9 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog
index 6350650..fdc2bf4 100644
--- a/gdb/testsuite/ChangeLog
+++ b/gdb/testsuite/ChangeLog
@@ -1,5 +1,13 @@
2012-01-16 Pedro Alves <palves@redhat.com>
+ * lib/gdb.exp (banned_procedures): New variable.
+ (banned_variables_traced): Rename to ...
+ (banned_traced): ... this.
+ (gdb_init): Also trace banned procedures.
+ (gdb_finish): Also untrace banned procedures.
+
+2012-01-16 Pedro Alves <palves@redhat.com>
+
Remove all calls to strace.
2012-01-14 Jan Kratochvil <jan.kratochvil@redhat.com>
diff --git a/gdb/testsuite/lib/gdb.exp b/gdb/testsuite/lib/gdb.exp
index 4a59944..00fe71c 100644
--- a/gdb/testsuite/lib/gdb.exp
+++ b/gdb/testsuite/lib/gdb.exp
@@ -2983,14 +2983,19 @@ if ![info exists gdb_test_timeout] {
# an error when that happens.
set banned_variables { bug_id prms_id }
+# A list of procedures that GDB testcases should not use.
+# We try to prevent their use by monitoring invocations and raising
+# an error when that happens.
+set banned_procedures { strace }
+
# gdb_init is called by runtest at start, but also by several
# tests directly; gdb_finish is only called from within runtest after
# each test source execution.
# Placing several traces by repetitive calls to gdb_init leads
# to problems, as only one trace is removed in gdb_finish.
# To overcome this possible problem, we add a variable that records
-# if the banned variables are traced.
-set banned_variables_traced 0
+# if the banned variables and procedures are already traced.
+set banned_traced 0
proc gdb_init { args } {
# Reset the timeout value to the default. This way, any testcase
@@ -3000,15 +3005,21 @@ proc gdb_init { args } {
global timeout
set timeout $gdb_test_timeout
- # Block writes to all banned variables...
+ # Block writes to all banned variables, and invocation of all
+ # banned procedures...
global banned_variables
- global banned_variables_traced
- if (!$banned_variables_traced) {
+ global banned_procedures
+ global banned_traced
+ if (!$banned_traced) {
foreach banned_var $banned_variables {
global "$banned_var"
trace add variable "$banned_var" write error
}
- set banned_variables_traced 1
+ foreach banned_proc $banned_procedures {
+ global "$banned_proc"
+ trace add execution "$banned_proc" enter error
+ }
+ set banned_traced 1
}
# We set LC_ALL, LC_CTYPE, and LANG to C so that we get the same
@@ -3057,13 +3068,18 @@ proc gdb_finish { } {
# Unblock write access to the banned variables. Dejagnu typically
# resets some of them between testcases.
global banned_variables
- global banned_variables_traced
- if ($banned_variables_traced) {
+ global banned_procedures
+ global banned_traced
+ if ($banned_traced) {
foreach banned_var $banned_variables {
global "$banned_var"
trace remove variable "$banned_var" write error
}
- set banned_variables_traced 0
+ foreach banned_proc $banned_procedures {
+ global "$banned_proc"
+ trace remove execution "$banned_proc" enter error
+ }
+ set banned_traced 0
}
}