Skip to content

Commit dbf2e26

Browse files
committed
Prevent passing gmake's environment variables down through pg_regress.
When we do "make install" to create a temp installation, we don't want that instance of make to try to communicate with any instance of make that might be calling us. This is known to cause problems if the upper make has a -jN flag, and in principle could cause problems even without that. Unset the relevant environment variables to prevent such issues. Andres Freund
1 parent 4ef4159 commit dbf2e26

File tree

1 file changed

+13
-0
lines changed

1 file changed

+13
-0
lines changed

src/test/regress/pg_regress.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -786,6 +786,19 @@ initialize_environment(void)
786786
doputenv("PGPORT", s);
787787
}
788788

789+
/*
790+
* GNU make stores some flags in the MAKEFLAGS environment variable to
791+
* pass arguments to its own children. If we are invoked by make,
792+
* that causes the make invoked by us to think its part of the make
793+
* task invoking us, and so it tries to communicate with the toplevel
794+
* make. Which fails.
795+
*
796+
* Unset the variable to protect against such problems. We also reset
797+
* MAKELEVEL to be certain the child doesn't notice the make above us.
798+
*/
799+
unsetenv("MAKEFLAGS");
800+
unsetenv("MAKELEVEL");
801+
789802
/*
790803
* Adjust path variables to point into the temp-install tree
791804
*/

0 commit comments

Comments
 (0)