mirror of
https://git.savannah.gnu.org/git/make.git
synced 2025-01-12 16:45:35 +00:00
* tests/test_driver.pl: Show info about failed tests
Remove working directories for skipped tests. We use different directories per test so don't keep rmfiles.
This commit is contained in:
parent
05c86bfcb2
commit
24a84f99bb
2 changed files with 37 additions and 26 deletions
1
NEWS
1
NEWS
|
@ -35,6 +35,7 @@ https://sv.gnu.org/bugs/index.php?group=make&report_id=111&fix_release_id=111&se
|
|||
|
||||
* Tests in the regression test suite now are run in their own directory to
|
||||
avoid cross-contamination and allow cleanup if the tests are interrupted.
|
||||
More information is printed about failing tests.
|
||||
|
||||
|
||||
Version 4.4.1 (26 Feb 2023)
|
||||
|
|
|
@ -56,6 +56,8 @@ $some_test_failed = 0;
|
|||
$tests_run = 0;
|
||||
# The number of tests in this category that have passed
|
||||
$tests_passed = 0;
|
||||
# Info on which tests failed
|
||||
@failure_info = ();
|
||||
|
||||
$port_type = undef;
|
||||
$osname = undef;
|
||||
|
@ -387,9 +389,19 @@ sub toplevel
|
|||
print "s" unless $total_tests_failed == 1;
|
||||
print " in $categories_failed Categor";
|
||||
print ($categories_failed == 1 ? "y" : "ies");
|
||||
print " Failed (See .$diffext files in $workdir dir for details) :-(\n\n";
|
||||
print " Failed :-(\n\n";
|
||||
my $i = 0;
|
||||
for my $e (@failure_info) {
|
||||
++$i;
|
||||
print " Failure $i:\n";
|
||||
print " run: $e->{'run'}\n" if exists($e->{'run'});
|
||||
print " base: $e->{'base'}\n";
|
||||
print " diff: $e->{'diff'}\n" if exists($e->{'diff'});
|
||||
}
|
||||
return 0;
|
||||
} elsif ($some_test_failed) {
|
||||
}
|
||||
|
||||
if ($some_test_failed) {
|
||||
# Something failed but no tests were marked failed... probably a syntax
|
||||
# error in a test script
|
||||
print "\nSome tests failed (See output for details) :-(\n\n";
|
||||
|
@ -634,10 +646,10 @@ sub run_all_tests
|
|||
$testname =~ s/^$scriptpath$pathsep//;
|
||||
$testname =~ s/(\.pl|\.perl)$//;
|
||||
|
||||
$perl_testname = "$scriptpath$pathsep$testname";
|
||||
$perl_testname = File::Spec->catfile($scriptpath, $testname);
|
||||
-f $perl_testname or die "Invalid test: $testname\n\n";
|
||||
|
||||
$testpath = "$workpath$pathsep$testname";
|
||||
$testpath = File::Spec->catdir($workpath, $testname);
|
||||
|
||||
remove_directory_tree($testpath);
|
||||
mkdir($testpath, 0777) or &error("Couldn't mkdir $testpath: $!\n", 1);
|
||||
|
@ -680,6 +692,7 @@ sub run_all_tests
|
|||
# Skipped... not supported
|
||||
$status = "N/A";
|
||||
--$categories_run;
|
||||
remove_directory_tree($testpath);
|
||||
|
||||
} elsif ($code != 1) {
|
||||
# Bad result... this shouldn't really happen. Usually means that
|
||||
|
@ -737,18 +750,11 @@ sub run_all_tests
|
|||
close(INCOPY);
|
||||
}
|
||||
|
||||
# If the keep flag is not set, this subroutine deletes all filenames that
|
||||
# are sent to it.
|
||||
# Deletes all filenames that are sent to it.
|
||||
|
||||
sub rmfiles
|
||||
{
|
||||
my (@files) = @_;
|
||||
|
||||
if (!$keep) {
|
||||
return (unlink @files);
|
||||
}
|
||||
|
||||
return 1;
|
||||
return (unlink @_);
|
||||
}
|
||||
|
||||
sub print_standard_usage
|
||||
|
@ -995,6 +1001,7 @@ sub compare_output
|
|||
|
||||
++$tests_run;
|
||||
|
||||
# Check to see if any temporary files were leftover after the run completes
|
||||
my @tf = ();
|
||||
foreach my $file (glob(File::Spec->catfile($temppath, "*"))) {
|
||||
if (!exists $old_tempfiles{$file}) {
|
||||
|
@ -1014,13 +1021,19 @@ sub compare_output
|
|||
$matched = 1;
|
||||
} else {
|
||||
print "Comparing output ........ " if $debug;
|
||||
|
||||
$matched = compare_answer($answer, &read_file_into_string ($logfile));
|
||||
}
|
||||
|
||||
if ($keep || ! $matched) {
|
||||
&create_file(&get_basefile, $answer);
|
||||
&create_file(&get_runfile, $command_string);
|
||||
my $base = get_basefile();
|
||||
my $run = get_runfile();
|
||||
my $diff = get_difffile();
|
||||
|
||||
my %e = ('base' => File::Spec->catdir($testpath, $base));
|
||||
|
||||
if (! $matched) {
|
||||
&create_file($base, $answer);
|
||||
&create_file($run, $command_string);
|
||||
$e{'run'} = File::Spec->catdir($testpath, $run);
|
||||
}
|
||||
|
||||
if ($matched && $test_passed && !$extra) {
|
||||
|
@ -1030,21 +1043,18 @@ sub compare_output
|
|||
}
|
||||
|
||||
if (! $matched) {
|
||||
print "DIFFERENT OUTPUT\n" if $debug;
|
||||
|
||||
print "\nCreating Difference File ...\n" if $debug;
|
||||
|
||||
# Create the difference file
|
||||
my $base = get_basefile();
|
||||
if ($diff_name) {
|
||||
&run_command_with_output(get_difffile(),
|
||||
"$diff_name -c $base $logfile");
|
||||
run_command_with_output($diff, "$diff_name -c $base $logfile");
|
||||
} else {
|
||||
create_file(get_difffile(),
|
||||
"Log file $logfile differs from base file $base\n");
|
||||
create_file($diff, "Log file $logfile differs from base file $base\n");
|
||||
}
|
||||
|
||||
$e{'diff'} = File::Spec->catdir($testpath, $diff);
|
||||
}
|
||||
|
||||
push @failure_info, \%e;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue