forked from lix-project/hydra
* Keep the most recent builds for each job.
This commit is contained in:
parent
14960d6c53
commit
7c1465944f
2 changed files with 46 additions and 17 deletions
|
@ -5,6 +5,7 @@ use File::Path;
|
||||||
use File::Basename;
|
use File::Basename;
|
||||||
use Hydra::Schema;
|
use Hydra::Schema;
|
||||||
use Hydra::Helper::Nix;
|
use Hydra::Helper::Nix;
|
||||||
|
use POSIX qw(strftime);
|
||||||
|
|
||||||
my $db = openHydraDB;
|
my $db = openHydraDB;
|
||||||
|
|
||||||
|
@ -16,40 +17,67 @@ my %roots;
|
||||||
|
|
||||||
sub registerRoot {
|
sub registerRoot {
|
||||||
my ($path) = @_;
|
my ($path) = @_;
|
||||||
print "$path\n";
|
#print "$path\n";
|
||||||
|
|
||||||
mkpath($gcRootsDir) if !-e $gcRootsDir;
|
mkpath($gcRootsDir) if !-e $gcRootsDir;
|
||||||
|
|
||||||
my $link = "$gcRootsDir/" . basename $path;
|
my $link = "$gcRootsDir/" . basename $path;
|
||||||
|
|
||||||
if (!-e $link) {
|
if (!-l $link) {
|
||||||
symlink($path, $link)
|
symlink($path, $link)
|
||||||
or die "cannot creating symlink in $gcRootsDir to $path";
|
or die "cannot create symlink in $gcRootsDir to $path";
|
||||||
}
|
}
|
||||||
|
|
||||||
$roots{$path} = 1;
|
$roots{$path} = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# Determine which builds to keep automatically.
|
sub keepBuild {
|
||||||
my %pathsToKeep;
|
my ($build) = @_;
|
||||||
|
print "keeping build ", $build->id, " (",
|
||||||
# TODO
|
strftime("%Y-%m-%d %H:%M:%S", localtime($build->timestamp)), ")\n";
|
||||||
|
if (isValidPath($build->outpath)) {
|
||||||
|
registerRoot $build->outpath;
|
||||||
# For finished builds, we only keep the output path, not the derivation.
|
} else {
|
||||||
foreach my $build ($db->resultset('Builds')->search({finished => 1, buildStatus => 0}, {join => 'resultInfo'})) {
|
print STDERR "warning: output ", $build->outpath, " has disappeared\n";
|
||||||
if ($build->resultInfo->keep || defined $pathsToKeep{$build->outpath}) {
|
|
||||||
if (isValidPath($build->outpath)) {
|
|
||||||
registerRoot $build->outpath;
|
|
||||||
} else {
|
|
||||||
print STDERR "warning: output ", $build->outpath, " has disappeared\n";
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# Go over all jobs in all projects.
|
||||||
|
|
||||||
|
foreach my $project ($db->resultset('Projects')->all) {
|
||||||
|
|
||||||
|
foreach my $job ($project->builds->search({},
|
||||||
|
{select => [{distinct => 'attrname'}], as => ['attrname']}))
|
||||||
|
{
|
||||||
|
print "*** looking for builds to keep in ", $project->name, ":", $job->attrname, "\n";
|
||||||
|
|
||||||
|
# Keep the N most recent successful builds for each job and
|
||||||
|
# platform.
|
||||||
|
my @recentBuilds = $project->builds->search(
|
||||||
|
{ attrname => $job->attrname
|
||||||
|
, finished => 1
|
||||||
|
, buildStatus => 0 # == success
|
||||||
|
},
|
||||||
|
{ join => 'resultInfo'
|
||||||
|
, order_by => 'timestamp DESC'
|
||||||
|
, rows => 3 # !!! should make this configurable
|
||||||
|
});
|
||||||
|
|
||||||
|
keepBuild $_ foreach @recentBuilds;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# Keep all builds that have been marked as "keep".
|
||||||
|
print "*** looking for kept builds\n";
|
||||||
|
my @buildsToKeep = $db->resultset('Builds')->search({finished => 1, keep => 1}, {join => 'resultInfo'});
|
||||||
|
keepBuild $_ foreach @buildsToKeep;
|
||||||
|
|
||||||
|
|
||||||
# For scheduled builds, we register the derivation as a GC root.
|
# For scheduled builds, we register the derivation as a GC root.
|
||||||
|
print "*** looking for scheduled builds\n";
|
||||||
foreach my $build ($db->resultset('Builds')->search({finished => 0}, {join => 'schedulingInfo'})) {
|
foreach my $build ($db->resultset('Builds')->search({finished => 0}, {join => 'schedulingInfo'})) {
|
||||||
if (isValidPath($build->drvpath)) {
|
if (isValidPath($build->drvpath)) {
|
||||||
registerRoot $build->drvpath;
|
registerRoot $build->drvpath;
|
||||||
|
|
|
@ -340,6 +340,7 @@ create trigger cascadeReleaseSetUpdate
|
||||||
|
|
||||||
create table ReleaseSetJobs (
|
create table ReleaseSetJobs (
|
||||||
project text not null,
|
project text not null,
|
||||||
|
-- !!! urgh: "release" is a reserved keyword in sqlite >= 3.6.8!
|
||||||
release text not null,
|
release text not null,
|
||||||
|
|
||||||
job text not null,
|
job text not null,
|
||||||
|
|
Loading…
Reference in a new issue