Blame SOURCES/gdb-6.7-testsuite-stable-results.patch

4c2ad1
From FEDORA_PATCHES Mon Sep 17 00:00:00 2001
4c2ad1
From: Jan Kratochvil <jan.kratochvil@redhat.com>
4c2ad1
Date: Fri, 27 Oct 2017 21:07:50 +0200
4c2ad1
Subject: gdb-6.7-testsuite-stable-results.patch
4c2ad1
4c2ad1
;; Testsuite fixes for more stable/comparable results.
4c2ad1
;;=fedoratest
4c2ad1
4c2ad1
gdb/testsuite/gdb.base/fileio.c:
4c2ad1
gdb/testsuite/gdb.base/fileio.exp:
4c2ad1
2007-12-08  Jan Kratochvil  <jan.kratochvil@redhat.com>
4c2ad1
4c2ad1
	* gdb.base/fileio.c (ROOTSUBDIR): New macro.
4c2ad1
	(main): CHDIR into ROOTSUBDIR.  CHOWN ROOTSUBDIR and CHDIR into
4c2ad1
	ROOTSUBDIR if we are being run as root.
4c2ad1
	* gdb.base/fileio.exp: Change the startup and finish cleanup.
4c2ad1
	Change the test file reference to be into the `fileio.dir' directory.
4c2ad1
4c2ad1
sources/gdb/testsuite/gdb.base/dump.exp:
4c2ad1
Found on RHEL-5.s390x.
4c2ad1
4c2ad1
gdb-6.8.50.20090209/gdb/testsuite/gdb.base/auxv.exp:
4c2ad1
random FAIL: gdb.base/auxv.exp: matching auxv data from live and gcore
4c2ad1
4c2ad1
gdb-6.8.50.20090209/gdb/testsuite/gdb.base/annota1.exp:
4c2ad1
frames-invalid can happen asynchronously.
4c2ad1
4c2ad1
diff --git a/gdb/testsuite/gdb.base/fileio.c b/gdb/testsuite/gdb.base/fileio.c
4c2ad1
--- a/gdb/testsuite/gdb.base/fileio.c
4c2ad1
+++ b/gdb/testsuite/gdb.base/fileio.c
4c2ad1
@@ -560,6 +560,28 @@ strerrno (int err)
4c2ad1
 int
4c2ad1
 main ()
4c2ad1
 {
4c2ad1
+  /* These tests
4c2ad1
+       Open for write but no write permission returns EACCES
4c2ad1
+       Unlinking a file in a directory w/o write access returns EACCES
4c2ad1
+     fail if we are being run as root - drop the privileges here.  */
4c2ad1
+
4c2ad1
+  if (geteuid () == 0)
4c2ad1
+    {
4c2ad1
+      uid_t uid = 99;
4c2ad1
+
4c2ad1
+      if (chown (OUTDIR, uid, uid) != 0)
4c2ad1
+	{
4c2ad1
+	  printf ("chown %d.%d %s: %s\n", (int) uid, (int) uid,
4c2ad1
+		  OUTDIR, strerror (errno));
4c2ad1
+	  exit (1);
4c2ad1
+	}
4c2ad1
+      if (setuid (uid) || geteuid () == 0)
4c2ad1
+	{
4c2ad1
+	  printf ("setuid %d: %s\n", (int) uid, strerror (errno));
4c2ad1
+	  exit (1);
4c2ad1
+	}
4c2ad1
+    }
4c2ad1
+
4c2ad1
   /* Don't change the order of the calls.  They partly depend on each other */
4c2ad1
   test_open ();
4c2ad1
   test_write ();
4c2ad1
diff --git a/gdb/testsuite/gdb.base/fileio.exp b/gdb/testsuite/gdb.base/fileio.exp
4c2ad1
--- a/gdb/testsuite/gdb.base/fileio.exp
4c2ad1
+++ b/gdb/testsuite/gdb.base/fileio.exp
4c2ad1
@@ -24,9 +24,9 @@ if [target_info exists gdb,nofileio] {
4c2ad1
 standard_testfile
4c2ad1
 
4c2ad1
 if {[is_remote host]} {
4c2ad1
-    set outdir .
4c2ad1
+    set outdir "fileio.dir"
4c2ad1
 } else {
4c2ad1
-    set outdir [standard_output_file {}]
4c2ad1
+    set outdir [standard_output_file "fileio.dir"]
4c2ad1
 }
4c2ad1
 
4c2ad1
 if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" \
4c2ad1
@@ -47,7 +47,8 @@ set dir2 [standard_output_file dir2.fileio.test]
4c2ad1
 if {[file exists $dir2] && ![file writable $dir2]} {
4c2ad1
     system "chmod +w $dir2"
4c2ad1
 }
4c2ad1
-system "rm -rf [standard_output_file *.fileio.test]"
4c2ad1
+system "rm -rf [standard_output_file fileio.dir]"
4c2ad1
+system "mkdir -m777 [standard_output_file fileio.dir]"
4c2ad1
 
4c2ad1
 set oldtimeout $timeout
4c2ad1
 set timeout [expr "$timeout + 60"]
4c2ad1
@@ -89,7 +90,7 @@ gdb_test continue \
4c2ad1
 
4c2ad1
 gdb_test "continue" ".*" ""
4c2ad1
 
4c2ad1
-catch "system \"chmod -f -w [standard_output_file nowrt.fileio.test]\""
4c2ad1
+catch "system \"chmod -f -w [standard_output_file fileio.dir/nowrt.fileio.test]\""
4c2ad1
 
4c2ad1
 gdb_test continue \
4c2ad1
 "Continuing\\..*open 5:.*EACCES$stop_msg" \
4c2ad1
@@ -276,9 +277,7 @@ gdb_test continue \
4c2ad1
 gdb_exit
4c2ad1
 
4c2ad1
 # Make dir2 writable again so rm -rf of a build tree Just Works.
4c2ad1
-if {[file exists $dir2] && ![file writable $dir2]} {
4c2ad1
-    system "chmod +w $dir2"
4c2ad1
-}
4c2ad1
+system "chmod -R +w $outdir"
4c2ad1
 
4c2ad1
 set timeout $oldtimeout
4c2ad1
 return 0