gdb/testsuite: don't use source tree as temporary HOME directory
authorAndrew Burgess <andrew.burgess@embecosm.com>
Mon, 10 May 2021 15:49:56 +0000 (16:49 +0100)
committerAndrew Burgess <andrew.burgess@embecosm.com>
Mon, 10 May 2021 16:56:16 +0000 (17:56 +0100)
In this commit:

  commit 1845e254645efbc02248345ccdb557d265dd8ae1
  Date:   Wed May 5 16:50:17 2021 +0100

      gdb/guile: perform tilde expansion when sourcing guile scripts

A test was added that tries to source a guile script from the users
HOME directory.  In order to achieve this the test (temporarily)
modifies $HOME to point into the binutils-gdb source tree.

The problem with this is that sourcing a guile script can cause the
guile script to be byte compiled and written into a .cache/ directory,
which is stored .... in the $HOME directory.

The result was that the test added in the above commit would cause a
.cache/ directory to be added into the binutils-gdb source tree.

In this commit the test is updated to create a new directory in the
build tree, the file we want to source is copied over, and $HOME is
set to point at the location in the build tree.  Now when the test is
run the .cache/ directory is created in the build tree, leaving the
source tree untouched.

gdb/testsuite/ChangeLog:

* gdb.guile/guile.exp: Don't use the source directory as a
temporary HOME directory.

gdb/testsuite/ChangeLog
gdb/testsuite/gdb.guile/guile.exp

index a22e014b45a772ba996b5a3c64b44b6e04aba93a..b3a41bd5481893672056750aac4a21ac2fdf2d24 100644 (file)
@@ -1,3 +1,8 @@
+2021-05-10  Andrew Burgess  <andrew.burgess@embecosm.com>
+
+       * gdb.guile/guile.exp: Don't use the source directory as a
+       temporary HOME directory.
+
 2021-05-10  Simon Marchi  <simon.marchi@polymtl.ca>
 
        * gdb.arch/amd64-osabi.exp (test_osabi_none): Use the
index 0fb82284f465b5b0b6d0f02a2aa74a98e7615e28..33250ff6510d7f7dccfb75c810e59ef7b0bf5c5f 100644 (file)
@@ -85,7 +85,18 @@ gdb_test "guile (print a)" "= .*aliases -- User-defined aliases of other command
 
 # Verify that we can source a guile script using ~ for the HOME directory.
 save_vars { env(HOME) } {
-    set env(HOME) $srcdir/$subdir
+    # Create a new directory to act as a temporary HOME directory.
+    set tmp_home [standard_output_file tmp_home]
+    file mkdir $tmp_home
+
+    # Copy the file we want to source into the new HOME directory.
+    gdb_remote_download host ${srcdir}/${subdir}/source2.scm \
+       ${tmp_home}/source2.scm
+
+    # Arrange to use the new HOME directory.
+    set env(HOME) $tmp_home
     clean_restart
+
+    # Finally, source the file out of our new HOME directory.
     gdb_test "source ~/source2.scm" "yes"
 }