mirror of
https://git.savannah.gnu.org/git/make.git
synced 2025-01-13 01:07:36 +00:00
971b02d58e
Avoid cross-contamination between test files by creating a new working directory for each file, and setting it as the current directory before starting the tests in that file. Rename the test output as tNNN.{base,log,diff,mk} where NNN is a test number starting with 001 for the first test. It is slightly more annoying to find diff files since you can't use autocomplete directly but it is simpler to match things. Detect the source directory as the location of the test_driver.pl script, so remove the separate -srcdir option. * Makefile.am: Remove hacks to create symlinks when building out-of-tree, and remove -srcdir option from run_make_tests. * tests/test_driver.pl: Locate $srcpath based on __FILE__, then compute $toppath as its parent. Set $scriptpath under $srcpath and $workpath under the current directory. Toss $*_filename and modify get_logfile() etc. to use the suffix directly. Add a chdir() around the invocation of the test. * tests/run_make_tests.pl: Throw out the -srcdir option and use $srcpath set in test_driver.pl. The #WORK# helper is no longer useful so remove it. Set #PWD# to the current working dir. Always search the local directory and $srcpath for config-flags.pm. Use $srcpath for finding the thelp.pl script. * tests/scripts/features/vpath: Don't put things in work/ as it is no longer a subdirectory. * tests/scripts/features/vpathgpath: Ditto. * tests/scripts/features/vpathplus: Ditto. * tests/scripts/misc/general1: Ditto. * tests/scripts/misc/general2: Ditto. * tests/scripts/options/dash-k: Ditto. * tests/scripts/options/symlinks: Use $testpath as the working directory. * tests/scripts/variables/GNUMAKEFLAGS: Use the test helper to display env var values (grepping for GNUMAKEFLAGS finds extra things now that it is our current working directory).
116 lines
2.8 KiB
Perl
116 lines
2.8 KiB
Perl
# -*-perl-*-
|
|
|
|
$description = "Test the make -k (don't stop on error) option.\n";
|
|
|
|
$details = "\
|
|
The makefile created in this test is a simulation of building
|
|
a small product. However, the trick to this one is that one
|
|
of the dependencies of the main target does not exist.
|
|
Without the -k option, make would fail immediately and not
|
|
build any part of the target. What we are looking for here,
|
|
is that make builds the rest of the dependencies even though
|
|
it knows that at the end it will fail to rebuild the main target.";
|
|
|
|
open(MAKEFILE,"> $makefile");
|
|
|
|
# The Contents of the MAKEFILE ...
|
|
|
|
print MAKEFILE <<EOF;
|
|
VPATH = work
|
|
edit: main.o kbd.o commands.o display.o
|
|
\t\@echo cc -o edit main.o kbd.o commands.o display.o
|
|
|
|
main.o : main.c defs.h
|
|
\t\@echo cc -c main.c
|
|
|
|
kbd.o : kbd.c defs.h command.h
|
|
\t\@echo cc -c kbd.c
|
|
|
|
commands.o : command.c defs.h command.h
|
|
\t\@echo cc -c commands.c
|
|
|
|
display.o : display.c defs.h buffer.h
|
|
\t\@echo cc -c display.c
|
|
EOF
|
|
|
|
# END of Contents of MAKEFILE
|
|
|
|
close(MAKEFILE);
|
|
|
|
|
|
mkdir('work');
|
|
@files_to_touch = ("work${pathsep}main.c","work${pathsep}defs.h",
|
|
"work${pathsep}command.h",
|
|
"work${pathsep}commands.c","work${pathsep}display.c",
|
|
"work${pathsep}buffer.h",
|
|
"work${pathsep}command.c");
|
|
|
|
&touch(@files_to_touch);
|
|
|
|
if ($vos) {
|
|
$error_code = 3307;
|
|
}
|
|
else {
|
|
$error_code = 512;
|
|
}
|
|
|
|
&run_make_with_options($makefile, "-k", &get_logfile, $error_code);
|
|
|
|
# Create the answer to what should be produced by this Makefile
|
|
$answer = "cc -c main.c
|
|
$make_name: *** No rule to make target 'kbd.c', needed by 'kbd.o'.
|
|
cc -c commands.c
|
|
cc -c display.c
|
|
$make_name: Target 'edit' not remade because of errors.\n";
|
|
|
|
# COMPARE RESULTS
|
|
|
|
&compare_output($answer, &get_logfile(1));
|
|
|
|
unlink(@files_to_touch) unless $keep;
|
|
|
|
|
|
# TEST 1: Make sure that top-level targets that depend on targets that
|
|
# previously failed to build, aren't attempted. Regression for PR/1634.
|
|
|
|
$makefile2 = &get_tmpfile;
|
|
|
|
open(MAKEFILE, "> $makefile2");
|
|
print MAKEFILE <<'EOF';
|
|
.SUFFIXES:
|
|
|
|
all: exe1 exe2; @echo making $@
|
|
|
|
exe1 exe2: lib; @echo cp $^ $@
|
|
|
|
lib: foo.o; @echo cp $^ $@
|
|
|
|
foo.o: ; exit 1
|
|
EOF
|
|
|
|
close(MAKEFILE);
|
|
|
|
&run_make_with_options($makefile2, "-k", &get_logfile, $error_code);
|
|
|
|
$answer = "exit 1
|
|
$make_name: *** [$makefile2:9: foo.o] Error 1
|
|
$make_name: Target 'all' not remade because of errors.\n";
|
|
|
|
&compare_output($answer, &get_logfile(1));
|
|
|
|
# TEST -- make sure we keep the error code if we can't create an included
|
|
# makefile.
|
|
|
|
if (defined $ERR_no_such_file) {
|
|
run_make_test('all: ; @echo hi
|
|
include ifile
|
|
ifile: no-such-file; exit 1
|
|
',
|
|
'-k',
|
|
"#MAKEFILE#:2: ifile: $ERR_no_such_file
|
|
#MAKE#: *** No rule to make target 'no-such-file', needed by 'ifile'.
|
|
#MAKEFILE#:2: failed to remake makefile 'ifile'",
|
|
512);
|
|
}
|
|
|
|
1;
|