From 044035ce85d089a9bbdfd6fa99c31dd22b74e7db Mon Sep 17 00:00:00 2001 From: Stefano Lattarini Date: Mon, 4 Jul 2011 11:41:34 +0200 Subject: [PATCH] remake: add test ensuring that slower remakes don't hang * tests/remake-subdir-long-time.test: New test. * tests/Makefile.am (TESTS): Update. Suggestion by Ralf Wildenhues. --- ChangeLog | 7 ++ tests/Makefile.am | 1 + tests/Makefile.in | 1 + tests/remake-subdir-long-time.test | 116 +++++++++++++++++++++++++++++ 4 files changed, 125 insertions(+) create mode 100755 tests/remake-subdir-long-time.test diff --git a/ChangeLog b/ChangeLog index 80506a7f6..7108823ee 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2011-07-04 Stefano Lattarini + + remake: add test ensuring that slower remakes don't hang + * tests/remake-subdir-long-time.test: New test. + * tests/Makefile.am (TESTS): Update. + Suggestion by Ralf Wildenhues. + 2011-07-04 Stefano Lattarini remake: fix outdated comment in configure.am diff --git a/tests/Makefile.am b/tests/Makefile.am index 33ae8bc62..9c5c03fb7 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -658,6 +658,7 @@ remake-subdir-from-subdir.test \ remake-subdir-gnu.test \ remake-subdir.test \ remake-subdir2.test \ +remake-subdir-long-time.test \ pr8365-remake-timing.test \ regex.test \ req.test \ diff --git a/tests/Makefile.in b/tests/Makefile.in index ad45cffbd..1b0175787 100644 --- a/tests/Makefile.in +++ b/tests/Makefile.in @@ -926,6 +926,7 @@ remake-subdir-from-subdir.test \ remake-subdir-gnu.test \ remake-subdir.test \ remake-subdir2.test \ +remake-subdir-long-time.test \ pr8365-remake-timing.test \ regex.test \ req.test \ diff --git a/tests/remake-subdir-long-time.test b/tests/remake-subdir-long-time.test new file mode 100755 index 000000000..18ba7326e --- /dev/null +++ b/tests/remake-subdir-long-time.test @@ -0,0 +1,116 @@ +#! /bin/sh +# Copyright (C) 2011 Free Software Foundation, Inc. +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# Check that remake rules from subdirectories do not hang or cycle +# endlessly, even with build systems that takes several seconds to +# rebuild the Makefiles. +# This test tries to ensure a long-enough rebuild time by introducing +# an explicit delay in the build process. +# Suggestion by Ralf Wildenhues. + +. ./defs || Exit 1 + +set -e + +cat > configure.in < Makefile.am +mkdir sub +: > sub/Makefile.am + +# Both aclocal and automake are expected to run one and just one time. +# Create and use wrappers that will verify that. + +ocwd=`pwd` || fatal_ "cannot get current working directory" + +mkdir bin + +cat > bin/automake <&2 + exit 1 +else + echo automake has run > "\$sentinel" +fi +$sleep; $sleep; +exec $AUTOMAKE \${1+"\$@"} +END +chmod a+x bin/automake + +cat > bin/aclocal <&2 + exit 1 +else + echo aclocal has run > "\$sentinel" +fi +$sleep; $sleep; +exec $ACLOCAL \${1+"\$@"} +END +chmod a+x bin/aclocal + +# Just to be sure. +cp bin/automake bin/automake-$APIVERSION +cp bin/aclocal bin/aclocal-$APIVERSION + +PATH=$ocwd/bin$PATH_SEPARATOR$PATH; export PATH + +AUTOMAKE=automake ACLOCAL=aclocal; export AUTOMAKE ACLOCAL + +$ACLOCAL # Should use or just-defined wrapper. +$AUTOMAKE # Likewise. +$AUTOCONF + +# Sanity check: the wrappers have been used. +test -f automake-has-run +test -f aclocal-has-run +rm -f automake-has-run aclocal-has-run + +./configure +# Sanity check: Makefile doesn't get updated uselessly. +ACLOCAL=false AUTOMAKE=false AUTOCONF=false $MAKE -e + +$sleep +sed "s|magic|magic2|" configure.in > t +mv -f t configure.in + +cd sub +AUTOMAKE="$AUTOMAKE" ACLOCAL="$ACLOCAL" $MAKE -e Makefile +cd .. + +# For debugging. +ls -l . sub +grep -i magic configure Makefile.in Makefile sub/Makefile.in sub/Makefile +# Sanity checks. +$FGREP magic2 configure +$FGREP magic2 Makefile +$FGREP magic2 sub/Makefile + +: -- 2.47.2