forked from lix-project/hydra
If a build step fail, immediately fail all queued builds that depend on it
This prevents unnecessary work, but it's mostly a refactoring to support combining notification emails.
This commit is contained in:
parent
507e5bb190
commit
f762d111f1
1 changed files with 55 additions and 4 deletions
|
@ -215,6 +215,57 @@ sub addBuildStepOutputs {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub nextFreeStepNr {
|
||||||
|
my ($build) = @_;
|
||||||
|
my $max = $build->buildsteps->find(
|
||||||
|
{}, {select => {max => 'stepnr + 1'}, as => ['max']});
|
||||||
|
return (defined $max && defined $max->get_column('max')) ? $max->get_column('max') : 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub failDependents {
|
||||||
|
my ($drvPath, $errorMsg) = @_;
|
||||||
|
|
||||||
|
# Get the referrer closure of $drvPath.
|
||||||
|
my @dependentDrvs = computeFSClosure(1, 0, $drvPath);
|
||||||
|
|
||||||
|
my $time = time();
|
||||||
|
|
||||||
|
txn_do($db, sub {
|
||||||
|
|
||||||
|
my @dependentBuilds = $db->resultset('Builds')->search(
|
||||||
|
{ drvpath => [ @dependentDrvs ], finished => 0, busy => 0 });
|
||||||
|
|
||||||
|
for my $d (@dependentBuilds) {
|
||||||
|
print STDERR "failing dependent build ", $d->id, " of ", $d->project->name, ":", $d->jobset->name, ":", $d->job->name, "\n";
|
||||||
|
$d->update(
|
||||||
|
{ finished => 1
|
||||||
|
, logfile => ''
|
||||||
|
, timestamp => time # !!! Why change the timestamp?
|
||||||
|
, iscachedbuild => 0
|
||||||
|
, buildstatus => $drvPath eq $d->drvpath ? 1 : 2
|
||||||
|
, starttime => $time
|
||||||
|
, stoptime => $time
|
||||||
|
, errormsg => undef
|
||||||
|
});
|
||||||
|
|
||||||
|
my $step = $d->buildsteps->create(
|
||||||
|
{ stepnr => nextFreeStepNr($d)
|
||||||
|
, type => 0 # = build
|
||||||
|
, drvpath => $drvPath
|
||||||
|
, busy => 0
|
||||||
|
, status => 1
|
||||||
|
, starttime => time
|
||||||
|
, stoptime => time
|
||||||
|
, errormsg => $errorMsg
|
||||||
|
});
|
||||||
|
addBuildStepOutputs($step);
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
sub doBuild {
|
sub doBuild {
|
||||||
my ($build) = @_;
|
my ($build) = @_;
|
||||||
|
|
||||||
|
@ -252,10 +303,7 @@ sub doBuild {
|
||||||
"--no-build-output --log-type flat --print-build-trace " .
|
"--no-build-output --log-type flat --print-build-trace " .
|
||||||
"--add-root " . gcRootFor($outputs{out} // $outputs{(sort keys %outputs)[0]}) . " 2>&1";
|
"--add-root " . gcRootFor($outputs{out} // $outputs{(sort keys %outputs)[0]}) . " 2>&1";
|
||||||
|
|
||||||
my $max = $build->buildsteps->find(
|
my $buildStepNr = nextFreeStepNr($build);
|
||||||
{}, {select => {max => 'stepnr + 1'}, as => ['max']});
|
|
||||||
my $buildStepNr = (defined $max && defined $max->get_column('max')) ? $max->get_column('max') : 1;
|
|
||||||
|
|
||||||
my %buildSteps;
|
my %buildSteps;
|
||||||
|
|
||||||
open OUT, "$cmd |" or die;
|
open OUT, "$cmd |" or die;
|
||||||
|
@ -328,6 +376,9 @@ sub doBuild {
|
||||||
addBuildStepOutputs($step);
|
addBuildStepOutputs($step);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
# Immediately fail all builds that depend on this derivation.
|
||||||
|
failDependents($drvPathStep, $errorMsg);
|
||||||
}
|
}
|
||||||
|
|
||||||
elsif (/^@\s+substituter-started\s+(\S+)\s+(\S+)$/) {
|
elsif (/^@\s+substituter-started\s+(\S+)\s+(\S+)$/) {
|
||||||
|
|
Loading…
Reference in a new issue