diff options
author | Stefano Lattarini <stefano.lattarini@gmail.com> | 2012-04-06 13:12:25 +0200 |
---|---|---|
committer | Stefano Lattarini <stefano.lattarini@gmail.com> | 2012-04-06 21:29:30 +0200 |
commit | 8a5096d150cf9803b8963768b7366cd68edcce03 (patch) | |
tree | a49c0e54876b8b9877d7ca2df386377e7b6037d1 /t/subst3.sh | |
parent | f8e822bbc197f01fc722aa6def7cddb4182e3c66 (diff) | |
download | automake-8a5096d150cf9803b8963768b7366cd68edcce03.tar.gz |
tests: rename 'tests/' => 't/', '*.test' => '*.sh'
When we (soon) convert the Automake testsuite to a non-recursive
make setup, we'll have to fix the entries of $(TESTS) to be
prepended with the subdirectory they are in; this will increase
the length of $(TESTS), and thus increase the possibility of
exceeding the command-line length limits on some systems (most
notably, MinGW/MSYS). See automake bug#7868 for more information.
Thus we rename the 'tests/' subdirectory to 't/', and each 'x.test'
script in there to 'x.sh'; this way, the $(TESTS) entry 'foo.test'
will become 't/foo.sh', which have the same number of characters.
* tests/: Rename ...
* t/: ... to this.
* t/*.test: Rename ...
* t/*.sh: ... to this.
* t/.gitignore: Removed as obsolete.
* t/defs: Adjust.
* t/gen-testsuite-part: Likewise.
* t/list-of-tests.mk: Likewise.
* t/ccnoco.sh: Likewise.
* t/ccnoco3.sh: Likewise.
* t/self-check-cleanup.tap: Likewise.
* t/self-check-dir.tap: Likewise.
* t/self-check-me.tap: Likewise.
* t/self-check-reexec.tap: Likewise.
* README: Likewise.
* bootstrap: Likewise
* configure.ac: Likewise.
* Makefile.am: Likewise.
* .gitignore: Likewise.
* syntax-check.mk: Likewise.
Signed-off-by: Stefano Lattarini <stefano.lattarini@gmail.com>
Diffstat (limited to 't/subst3.sh')
-rwxr-xr-x | t/subst3.sh | 177 |
1 files changed, 177 insertions, 0 deletions
diff --git a/t/subst3.sh b/t/subst3.sh new file mode 100755 index 000000000..cc81063e3 --- /dev/null +++ b/t/subst3.sh @@ -0,0 +1,177 @@ +#! /bin/sh +# Copyright (C) 2001-2012 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 <http://www.gnu.org/licenses/>. + +# Test installation with substitutions. This test is based on nobase.test. + +required=cc +. ./defs || Exit 1 + +cat >> configure.ac <<'EOF' +AC_PROG_CC +AM_PROG_AR +AC_PROG_RANLIB +if test -n "$doit"; then + AC_SUBST([basehdr], [sub/base.h]) + AC_SUBST([nobasehdr], [sub/nobase.h]) + AC_SUBST([basedata], [sub/base.dat]) + AC_SUBST([nobasedata], [sub/nobase.dat]) + AC_SUBST([basescript], [sub/base.sh]) + AC_SUBST([nobasescript], [sub/nobase.sh]) + AC_SUBST([baseprog], ['sub/base$(EXEEXT)']) + AC_SUBST([nobaseprog], ['sub/nobase$(EXEEXT)']) + AC_SUBST([baselib], [sub/libbase.a]) + AC_SUBST([nobaselib], [sub/libnobase.a]) +fi +AC_OUTPUT +EOF + +cat > Makefile.am << 'EOF' +foodir = $(prefix)/foo +fooexecdir = $(prefix)/foo + +foo_HEADERS = @basehdr@ +nobase_foo_HEADERS = @nobasehdr@ +EXTRA_HEADERS = sub/base.h sub/nobase.h + +dist_foo_DATA = @basedata@ +nobase_dist_foo_DATA = @nobasedata@ + +dist_fooexec_SCRIPTS = @basescript@ +nobase_dist_fooexec_SCRIPTS = @nobasescript@ +EXTRA_SCRIPTS = sub/base.sh sub/nobase.sh + +fooexec_PROGRAMS = @baseprog@ +nobase_fooexec_PROGRAMS = @nobaseprog@ +EXTRA_PROGRAMS = sub/base sub/nobase +sub_base_SOURCES = source.c +sub_nobase_SOURCES = source.c + +fooexec_LIBRARIES = @baselib@ +nobase_fooexec_LIBRARIES = @nobaselib@ +EXTRA_LIBRARIES = sub/libbase.a sub/libnobase.a +sub_libbase_a_SOURCES = source.c +sub_libnobase_a_SOURCES = source.c + +test-install-data: install-data + test -f inst/foo/sub/nobase.h + test ! -f inst/foo/nobase.h + test -f inst/foo/base.h + test -f inst/foo/sub/nobase.dat + test ! -f inst/foo/nobase.dat + test -f inst/foo/base.dat + test ! -f inst/foo/sub/pnobase.sh + test ! -f inst/foo/pbase.sh + test ! -f inst/foo/sub/pnobase$(EXEEXT) + test ! -f inst/foo/pbase$(EXEEXT) + test ! -f inst/foo/sub/libnobase.a + test ! -f inst/foo/libbase.a + +test-install-exec: install-exec + test -f inst/foo/sub/pnobase.sh + test ! -f inst/foo/pnobase.sh + test -f inst/foo/pbase.sh + test -f inst/foo/sub/pnobase$(EXEEXT) + test ! -f inst/foo/pnobase$(EXEEXT) + test -f inst/foo/pbase$(EXEEXT) + test -f inst/foo/sub/libnobase.a + test ! -f inst/foo/libnobase.a + test -f inst/foo/libbase.a + +test-install-nothing-data: install-data + test ! -f inst/foo/sub/nobase.h + test ! -f inst/foo/nobase.h + test ! -f inst/foo/base.h + test ! -f inst/foo/sub/nobase.dat + test ! -f inst/foo/nobase.dat + test ! -f inst/foo/base.dat + test ! -f inst/foo/sub/pnobase.sh + test ! -f inst/foo/pbase.sh + test ! -f inst/foo/sub/pnobase$(EXEEXT) + test ! -f inst/foo/pbase$(EXEEXT) + test ! -f inst/foo/sub/libnobase.a + test ! -f inst/foo/libbase.a + +test-install-nothing-exec: install-exec + test ! -f inst/foo/sub/pnobase.sh + test ! -f inst/foo/pnobase.sh + test ! -f inst/foo/pbase.sh + test ! -f inst/foo/sub/pnobase$(EXEEXT) + test ! -f inst/foo/pnobase$(EXEEXT) + test ! -f inst/foo/pbase$(EXEEXT) + test ! -f inst/foo/sub/libnobase.a + test ! -f inst/foo/libnobase.a + test ! -f inst/foo/libbase.a +EOF + +mkdir sub + +: > sub/base.h +: > sub/nobase.h +: > sub/base.dat +: > sub/nobase.dat +: > sub/base.sh +: > sub/nobase.sh + +cat >source.c <<'EOF' +int +main (int argc, char *argv[]) +{ + return 0; +} +EOF +cp source.c source2.c + +rm -f install-sh + +$ACLOCAL +$AUTOCONF +$AUTOMAKE -a --copy +./configure --prefix "`pwd`/inst" --program-prefix=p doit=yes + +$MAKE +$MAKE test-install-data +$MAKE test-install-exec +$MAKE uninstall +$MAKE clean + +test `find inst/foo -type f -print | wc -l` = 0 + +./configure --prefix "`pwd`/inst" --program-prefix=p doit= + +$MAKE +$MAKE test-install-nothing-data +$MAKE test-install-nothing-exec +$MAKE uninstall + + +# Likewise, in a VPATH build. + +$MAKE distclean +mkdir build +cd build +../configure --prefix "`pwd`/inst" --program-prefix=p doit=yes +$MAKE +$MAKE test-install-data +$MAKE test-install-exec +$MAKE uninstall +test `find inst/foo -type f -print | wc -l` = 0 + +../configure --prefix "`pwd`/inst" --program-prefix=p doit= +$MAKE +$MAKE test-install-nothing-data +$MAKE test-install-nothing-exec + +: |