public inbox for gdb-patches@sourceware.org
 help / color / mirror / Atom feed
* [PATCH 1/2] testsuite: Fix save-trace.exp writing outside standard output directory
@ 2016-02-15 20:24 Simon Marchi
  2016-02-15 20:24 ` [PATCH 2/2] testsuite: Make standard_temp_file use invocation-specific directories Simon Marchi
  2016-02-15 23:45 ` [PATCH 1/2] testsuite: Fix save-trace.exp writing outside standard output directory Pedro Alves
  0 siblings, 2 replies; 5+ messages in thread
From: Simon Marchi @ 2016-02-15 20:24 UTC (permalink / raw)
  To: gdb-patches; +Cc: Simon Marchi

In save-trace.exp, we want to test loading of a tracepoint definition
file with a relative path (I am not sure why in fact).  We currently use
"savetrace-relative.tr", which ends up directly in testsuite/.  If we
use [standard_output_file] on that path, it becomes absolute.  I decided
to just replace [pwd] with . (a dot) in the path given by
standard_output_file to make it relative.  However, this trick only
works because [pwd] is a prefix of the standard output directory.  So I
added a check to verify that precondition.

gdb/testsuite/ChangeLog:

	* gdb.trace/save-trace.exp: Change relative path to be in the
	standard output directory.
---
 gdb/testsuite/gdb.trace/save-trace.exp | 13 ++++++++++++-
 1 file changed, 12 insertions(+), 1 deletion(-)

diff --git a/gdb/testsuite/gdb.trace/save-trace.exp b/gdb/testsuite/gdb.trace/save-trace.exp
index 7c897bb..3819034 100644
--- a/gdb/testsuite/gdb.trace/save-trace.exp
+++ b/gdb/testsuite/gdb.trace/save-trace.exp
@@ -151,7 +151,18 @@ proc do_save_load_test { save_path } {
 gdb_verify_tracepoints "verify trace setup"
 
 with_test_prefix "relative" {
-    do_save_load_test "savetrace-relative.tr"
+    set filepath [standard_output_file "savetrace-relative.tr"]
+
+    # This only work because the pwd is a prefix of the standard output
+    # directory.  If this assumption becomes false, then this test needs to be
+    # changed (the relative path from [pwd] to the standard output directory
+    # will become a bit more complicated to compute).
+    if {[string first [pwd] $filepath] != 0} {
+	error "[pwd] is not a prefix of $filepath."
+    }
+
+    set filepath [string map "[pwd] ." $filepath]
+    do_save_load_test "$filepath"
 }
 
 with_test_prefix "absolute" {
-- 
2.5.1

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2016-02-16 14:02 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-02-15 20:24 [PATCH 1/2] testsuite: Fix save-trace.exp writing outside standard output directory Simon Marchi
2016-02-15 20:24 ` [PATCH 2/2] testsuite: Make standard_temp_file use invocation-specific directories Simon Marchi
2016-02-15 23:46   ` Pedro Alves
2016-02-15 23:45 ` [PATCH 1/2] testsuite: Fix save-trace.exp writing outside standard output directory Pedro Alves
2016-02-16 14:02   ` Simon Marchi

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).