mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-24 21:25:41 +00:00
Implement "new/removed/broken/fixed" tests
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5399 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b344030725
commit
d9bdbaac96
@ -39,7 +39,7 @@ sub WriteFile { # (filename, contents)
|
||||
}
|
||||
|
||||
sub GetRegex { # (Regex with ()'s, value)
|
||||
$_[1] =~ /$_[0]/;
|
||||
$_[1] =~ /$_[0]/m;
|
||||
return $1;
|
||||
}
|
||||
|
||||
@ -134,6 +134,8 @@ system "(time -p cvs -d $CVSRootDir co llvm) > $Prefix-CVS-Log.txt 2>&1"
|
||||
|
||||
chdir "llvm" or die "Could not change into llvm directory!";
|
||||
|
||||
system "cvs up -P -d > /dev/null 2>&1" if (!$NOCHECKOUT);
|
||||
|
||||
# Read in the HTML template file...
|
||||
undef $/;
|
||||
my $TemplateContents = ReadFile $Template;
|
||||
@ -172,7 +174,10 @@ my @Linked = split '\n', `grep Linking $Prefix-Build-Log.txt`;
|
||||
my $NumExecutables = scalar(grep(/executable/, @Linked));
|
||||
my $NumLibraries = scalar(grep(!/executable/, @Linked));
|
||||
my $NumObjects = `grep '^Compiling' $Prefix-Build-Log.txt | wc -l` + 0;
|
||||
my $BuildTime = GetRegex "([0-9.]+)", `grep '^real' $Prefix-Build-Log.txt`;
|
||||
my $BuildTimeU = GetRegex "([0-9.]+)", `grep '^user' $Prefix-Build-Log.txt`;
|
||||
my $BuildTimeS = GetRegex "([0-9.]+)", `grep '^sys' $Prefix-Build-Log.txt`;
|
||||
my $BuildWallTime = GetRegex "([0-9.]+)", `grep '^real' $Prefix-Build-Log.txt`;
|
||||
my $BuildTime = $BuildTimeU+$BuildTimeS; # BuildTime = User+System
|
||||
my $BuildError = "";
|
||||
if (`grep '^gmake: .*Error' $Prefix-Build-Log.txt | wc -l` + 0) {
|
||||
$BuildError = "<h3>Build error: compilation <a href=\"$DATE-Build-Log.txt\">"
|
||||
@ -219,27 +224,35 @@ $WarningsRemoved = AddPreTag $WarningsRemoved;
|
||||
my (%AddedFiles, %ModifiedFiles, %RemovedFiles,
|
||||
%UsersCommitted, %UsersUpdated);
|
||||
|
||||
my $DateRE = "[-:0-9 ]+\\+[0-9]+";
|
||||
|
||||
# Loop over every record from the CVS history, filling in the hashes.
|
||||
foreach $File (@CVSHistory) {
|
||||
my ($Type, $Date, $UID, $Rev, $Filename);
|
||||
if ($File =~ /([AMR]) ([-:0-9 ]+\+[0-9]+) ([^ ]+) ([0-9.]+) +([^ ]+) +([^ ]+)/) {
|
||||
if ($File =~ /([AMRUGC])\s($DateRE)\s([^\s]+)\s+([0-9.]+)\s+([^\s]+)\s+([^\s]+)/) {
|
||||
($Type, $Date, $UID, $Rev, $Filename) = ($1, $2, $3, $4, "$6/$5");
|
||||
} elsif ($File =~ /([OCGUW]) ([-:0-9 ]+\+[0-9]+) ([^ ]+)/) {
|
||||
($Type, $Date, $UID, $Rev, $Filename) = ($1, $2, $3, "", "");
|
||||
}
|
||||
#print "Ty = $Type Date = '$Date' UID=$UID Rev=$Rev File = '$Filename'\n";
|
||||
|
||||
if ($Type eq 'M') { # Modified
|
||||
$ModifiedFiles{$Filename} = 1;
|
||||
$UsersCommitted{$UID} = 1;
|
||||
} elsif ($Type eq 'A') { # Added
|
||||
$AddedFiles{$Filename} = 1;
|
||||
$UsersCommitted{$UID} = 1;
|
||||
} elsif ($Type eq 'R') { # Removed
|
||||
$RemovedFiles{$Filename} = 1;
|
||||
$UsersCommitted{$UID} = 1;
|
||||
} elsif ($File =~ /([W])\s($DateRE)\s([^\s]+) +([^\s]+)\s+([^\s]+)/) {
|
||||
($Type, $Date, $UID, $Rev, $Filename) = ($1, $2, $3, $4, "$6/$5");
|
||||
} elsif ($File =~ /([O]) ($DateRE) ([^ ]+) +([^\s]+)/) {
|
||||
($Type, $Date, $UID, $Rev, $Filename) = ($1, $2, $3, "", "$4/");
|
||||
} else {
|
||||
$UsersUpdated{$UID} = 1;
|
||||
print "UNMATCHABLE: $File\n";
|
||||
}
|
||||
# print "$File\nTy = $Type Date = '$Date' UID=$UID Rev=$Rev File = '$Filename'\n";
|
||||
|
||||
if ($Filename =~ /^llvm/) {
|
||||
if ($Type eq 'M') { # Modified
|
||||
$ModifiedFiles{$Filename} = 1;
|
||||
$UsersCommitted{$UID} = 1;
|
||||
} elsif ($Type eq 'A') { # Added
|
||||
$AddedFiles{$Filename} = 1;
|
||||
$UsersCommitted{$UID} = 1;
|
||||
} elsif ($Type eq 'R') { # Removed
|
||||
$RemovedFiles{$Filename} = 1;
|
||||
$UsersCommitted{$UID} = 1;
|
||||
} else {
|
||||
$UsersUpdated{$UID} = 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -260,6 +273,43 @@ system "gmake $MAKEOPTS report.nightly.html TEST=nightly "
|
||||
|
||||
my $ProgramsTable = ReadFile "report.nightly.html";
|
||||
|
||||
#
|
||||
# Create a list of the tests which were run...
|
||||
#
|
||||
system "grep -E 'TEST-(PASS|FAIL)' < $Prefix-ProgramTest.txt "
|
||||
. "| sort --key=3 > $Prefix-Tests.txt";
|
||||
|
||||
my ($RTestsAdded, $RTestsRemoved) = DiffFiles "-Tests.txt";
|
||||
|
||||
my @RawTestsAddedArray = split '\n', $RTestsAdded;
|
||||
my @RawTestsRemovedArray = split '\n', $RTestsRemoved;
|
||||
|
||||
my %OldTests = map {GetRegex('TEST-....: (.+)', $_)=>$_} @RawTestsRemovedArray;
|
||||
my %NewTests = map {GetRegex('TEST-....: (.+)', $_)=>$_} @RawTestsAddedArray;
|
||||
|
||||
my ($TestsAdded, $TestsRemoved, $TestsFixed, $TestsBroken) = ("","","","");
|
||||
|
||||
foreach $Test (keys %NewTests) {
|
||||
if (!exists $OldTests{$Test}) { # TestAdded if in New but not old
|
||||
$TestsAdded = "$TestsAdded$Test\n";
|
||||
} else {
|
||||
if ($OldTests{$Test} =~ /TEST-PASS/) { # Was the old one a pass?
|
||||
$TestsBroken = "$TestsBroken$Test\n"; # New one must be a failure
|
||||
} else {
|
||||
$TestsFixed = "$TestsFixed$Test\n"; # No, new one is a pass.
|
||||
}
|
||||
}
|
||||
}
|
||||
foreach $Test (keys %OldTests) { # TestRemoved if in Old but not New
|
||||
$TestsRemoved = "$TestsRemoved$Test\n" if (!exists $NewTests{$Test});
|
||||
}
|
||||
|
||||
$TestsAdded = AddPreTag $TestsAdded;
|
||||
$TestsRemoved = AddPreTag $TestsRemoved;
|
||||
$TestsFixed = AddPreTag $TestsFixed;
|
||||
$TestsBroken = AddPreTag $TestsBroken;
|
||||
|
||||
|
||||
#
|
||||
# Get a list of the previous days that we can link to...
|
||||
#
|
||||
|
@ -52,7 +52,8 @@
|
||||
<li><a href="$DATE-Build-Log.txt">Compilation Log</a>
|
||||
<ul>
|
||||
$BuildError
|
||||
Time to build CVS tree: <b>$BuildTime</b> seconds<br>
|
||||
Time to build CVS tree: <b>$BuildTime</b> seconds
|
||||
(<b>$BuildWallTime</b> seconds wall time)<br>
|
||||
Number of object files compiled: <b>$NumObjects</b><br>
|
||||
Number of libraries linked: <b>$NumLibraries</b><br>
|
||||
Number of executables linked:<b> $NumExecutables</b><br>
|
||||
@ -85,10 +86,10 @@ $WarningsList<p>
|
||||
|
||||
<h2>Changes in the test suite:</h2>
|
||||
<ul>
|
||||
<li>New Tests: ...
|
||||
<li>Removed Tests: ...
|
||||
<li>Newly passing tests: ...
|
||||
<li>Newly failing tests: ...
|
||||
<li>New Tests: $TestsAdded
|
||||
<li>Removed Tests: $TestsRemoved
|
||||
<li>Newly passing tests: $TestsFixed
|
||||
<li>Newly failing tests: $TestsBroken
|
||||
</ul>
|
||||
|
||||
<br><br><center>
|
||||
|
Loading…
x
Reference in New Issue
Block a user