| 
									
										
										
										
											2011-11-30 17:32:50 +01:00
										 |  |  | #! /var/run/current-system/sw/bin/perl -w | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | use strict; | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  | use List::MoreUtils qw(all); | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | use File::Basename; | 
					
						
							| 
									
										
										
										
											2008-11-12 14:29:32 +00:00
										 |  |  | use File::stat; | 
					
						
							| 
									
										
										
										
											2011-11-30 17:22:31 +01:00
										 |  |  | use Nix::Store; | 
					
						
							| 
									
										
										
										
											2013-05-08 17:30:30 +02:00
										 |  |  | use Hydra::Plugin; | 
					
						
							| 
									
										
										
										
											2008-11-25 11:09:15 +00:00
										 |  |  | use Hydra::Schema; | 
					
						
							| 
									
										
										
										
											2008-11-28 14:36:04 +00:00
										 |  |  | use Hydra::Helper::Nix; | 
					
						
							| 
									
										
										
										
											2012-03-13 12:10:19 +01:00
										 |  |  | use Hydra::Model::DB; | 
					
						
							| 
									
										
										
										
											2010-09-01 08:52:54 +00:00
										 |  |  | use Hydra::Helper::AddBuilds; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-22 22:59:54 +00:00
										 |  |  | STDOUT->autoflush(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-13 12:10:19 +01:00
										 |  |  | my $db = Hydra::Model::DB->new(); | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-22 13:19:28 +01:00
										 |  |  | my $config = getHydraConfig(); | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-10 09:47:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  | sub addBuildStepOutputs { | 
					
						
							|  |  |  |     my ($step) = @_; | 
					
						
							|  |  |  |     my $drv = derivationFromPath($step->drvpath); | 
					
						
							|  |  |  |     $step->buildstepoutputs->create({ name => $_, path => $drv->{outputs}->{$_} }) | 
					
						
							|  |  |  |         foreach keys %{$drv->{outputs}}; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-03 18:30:13 +02:00
										 |  |  | 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); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-08 17:54:29 +02:00
										 |  |  | sub notify { | 
					
						
							|  |  |  |     my ($build, $dependents) = @_; | 
					
						
							|  |  |  |     foreach my $plugin (Hydra::Plugin->plugins) { | 
					
						
							|  |  |  |         next unless $plugin->can('buildFinished'); | 
					
						
							|  |  |  |         eval { | 
					
						
							|  |  |  |             $plugin->buildFinished($db, $config, $build, []); | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         if ($@) { | 
					
						
							|  |  |  |             print STDERR "$plugin->buildFinished: $@\n"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 12:54:37 +00:00
										 |  |  | sub doBuild { | 
					
						
							|  |  |  |     my ($build) = @_; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |     my %outputs; | 
					
						
							|  |  |  |     $outputs{$_->name} = $_->path foreach $build->buildoutputs->all; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-26 08:03:59 +00:00
										 |  |  |     my $drvPath   = $build->drvpath; | 
					
						
							|  |  |  |     my $maxsilent = $build->maxsilent; | 
					
						
							|  |  |  |     my $timeout   = $build->timeout; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     my $isCachedBuild = 1; | 
					
						
							|  |  |  |     my $outputCreated = 1; # i.e., the Nix build succeeded (but it could be a positive failure) | 
					
						
							|  |  |  |     my $startTime = 0; | 
					
						
							|  |  |  |     my $stopTime = 0; | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     my $buildStatus = 0; # = succeeded | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     my $errormsg = undef; | 
					
						
							| 
									
										
										
										
											2009-03-09 17:21:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |     unless (all { isValidPath($_) } values(%outputs)) { | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  |         $isCachedBuild = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-09 16:22:41 +00:00
										 |  |  |         # Do the build. | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  |         $startTime = time(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  |         my $thisBuildFailed = 0; | 
					
						
							|  |  |  |         my $someBuildFailed = 0; | 
					
						
							| 
									
										
										
										
											2012-06-26 12:00:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |         # Run Nix to perform the build, and monitor the stderr output | 
					
						
							|  |  |  |         # to get notifications about specific build steps, the | 
					
						
							|  |  |  |         # associated log files, etc. | 
					
						
							| 
									
										
										
										
											2010-11-22 12:20:04 +00:00
										 |  |  |         my $cmd = "nix-store --realise $drvPath " . | 
					
						
							| 
									
										
										
										
											2013-01-22 13:19:28 +01:00
										 |  |  |             "--timeout $timeout " . | 
					
						
							| 
									
										
										
										
											2010-05-26 08:03:59 +00:00
										 |  |  |             "--max-silent-time $maxsilent --keep-going --fallback " . | 
					
						
							| 
									
										
										
										
											2009-10-08 11:51:49 +00:00
										 |  |  |             "--no-build-output --log-type flat --print-build-trace " . | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |             "--add-root " . gcRootFor($outputs{out} // $outputs{(sort keys %outputs)[0]}) . " 2>&1"; | 
					
						
							| 
									
										
										
										
											2010-01-06 13:57:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-03 18:30:13 +02:00
										 |  |  |         my $buildStepNr = nextFreeStepNr($build); | 
					
						
							| 
									
										
										
										
											2009-03-16 16:56:47 +00:00
										 |  |  |         my %buildSteps; | 
					
						
							| 
									
										
										
										
											2012-06-26 12:00:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |         open OUT, "$cmd |" or die; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while (<OUT>) { | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  |             $errormsg .= $_; | 
					
						
							| 
									
										
										
										
											2012-06-26 12:00:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |             unless (/^@\s+/) { | 
					
						
							|  |  |  |                 print STDERR "$_"; | 
					
						
							|  |  |  |                 next; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2012-06-26 12:00:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |             if (/^@\s+build-started\s+(\S+)\s+(\S+)\s+(\S+)\s+(\S+)$/) { | 
					
						
							| 
									
										
										
										
											2013-01-22 13:19:28 +01:00
										 |  |  |                 my $drvPathStep = $1; | 
					
						
							| 
									
										
										
										
											2009-04-22 22:43:04 +00:00
										 |  |  |                 txn_do($db, sub { | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                     my $step = $build->buildsteps->create( | 
					
						
							| 
									
										
										
										
											2009-03-16 17:46:46 +00:00
										 |  |  |                         { stepnr => ($buildSteps{$drvPathStep} = $buildStepNr++) | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |                         , type => 0 # = build | 
					
						
							| 
									
										
										
										
											2009-03-16 17:46:46 +00:00
										 |  |  |                         , drvpath => $drvPathStep | 
					
						
							| 
									
										
										
										
											2010-08-31 15:27:46 +00:00
										 |  |  |                         , system => $3 | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |                         , busy => 1 | 
					
						
							| 
									
										
										
										
											2008-11-12 11:09:21 +00:00
										 |  |  |                         , starttime => time | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                     addBuildStepOutputs($step); | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |                 }); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2012-06-26 12:00:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-31 14:08:59 +00:00
										 |  |  |             elsif (/^@\s+build-remote\s+(\S+)\s+(\S+)$/) { | 
					
						
							|  |  |  |                 my $drvPathStep = $1; | 
					
						
							| 
									
										
										
										
											2013-01-22 13:19:28 +01:00
										 |  |  |                 my $machine = $2; | 
					
						
							| 
									
										
										
										
											2010-08-31 14:08:59 +00:00
										 |  |  |                 txn_do($db, sub { | 
					
						
							|  |  |  |                     my $step = $build->buildsteps->find({stepnr => $buildSteps{$drvPathStep}}) or die; | 
					
						
							|  |  |  |                     $step->update({machine => $machine}); | 
					
						
							|  |  |  |                 }); | 
					
						
							| 
									
										
										
										
											2013-01-22 13:19:28 +01:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2012-06-26 12:00:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-12 13:00:56 +00:00
										 |  |  |             elsif (/^@\s+build-succeeded\s+(\S+)\s+(\S+)$/) { | 
					
						
							| 
									
										
										
										
											2009-03-16 17:46:46 +00:00
										 |  |  |                 my $drvPathStep = $1; | 
					
						
							| 
									
										
										
										
											2009-04-22 22:43:04 +00:00
										 |  |  |                 txn_do($db, sub { | 
					
						
							| 
									
										
										
										
											2009-03-16 17:46:46 +00:00
										 |  |  |                     my $step = $build->buildsteps->find({stepnr => $buildSteps{$drvPathStep}}) or die; | 
					
						
							| 
									
										
										
										
											2013-01-22 23:01:29 +01:00
										 |  |  |                     $step->update({busy => 0, status => 0, stoptime => time}); | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |                 }); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-12 13:00:56 +00:00
										 |  |  |             elsif (/^@\s+build-failed\s+(\S+)\s+(\S+)\s+(\S+)\s+(.*)$/) { | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  |                 my $drvPathStep = $1; | 
					
						
							|  |  |  |                 $someBuildFailed = 1; | 
					
						
							|  |  |  |                 $thisBuildFailed = 1 if $drvPath eq $drvPathStep; | 
					
						
							| 
									
										
										
										
											2009-03-26 12:53:39 +00:00
										 |  |  |                 my $errorMsg = $4; | 
					
						
							|  |  |  |                 $errorMsg = "build failed previously (cached)" if $3 eq "cached"; | 
					
						
							| 
									
										
										
										
											2009-04-22 22:43:04 +00:00
										 |  |  |                 txn_do($db, sub { | 
					
						
							| 
									
										
										
										
											2009-03-16 16:56:47 +00:00
										 |  |  |                     if ($buildSteps{$drvPathStep}) { | 
					
						
							|  |  |  |                         my $step = $build->buildsteps->find({stepnr => $buildSteps{$drvPathStep}}) or die; | 
					
						
							| 
									
										
										
										
											2009-03-26 12:53:39 +00:00
										 |  |  |                         $step->update({busy => 0, status => 1, errormsg => $errorMsg, stoptime => time}); | 
					
						
							| 
									
										
										
										
											2009-04-22 14:41:12 +00:00
										 |  |  |                     } | 
					
						
							|  |  |  |                     # Don't write a record if this derivation already | 
					
						
							|  |  |  |                     # failed previously.  This can happen if this is a | 
					
						
							|  |  |  |                     # restarted build. | 
					
						
							|  |  |  |                     elsif (scalar $build->buildsteps->search({drvpath => $drvPathStep, type => 0, busy => 0, status => 1}) == 0) { | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                         my $step = $build->buildsteps->create( | 
					
						
							| 
									
										
										
										
											2009-03-26 12:53:39 +00:00
										 |  |  |                             { stepnr => ($buildSteps{$drvPathStep} = $buildStepNr++) | 
					
						
							| 
									
										
										
										
											2008-11-12 11:09:21 +00:00
										 |  |  |                             , type => 0 # = build | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  |                             , drvpath => $drvPathStep | 
					
						
							| 
									
										
										
										
											2008-11-12 11:09:21 +00:00
										 |  |  |                             , busy => 0 | 
					
						
							|  |  |  |                             , status => 1 | 
					
						
							|  |  |  |                             , starttime => time | 
					
						
							|  |  |  |                             , stoptime => time | 
					
						
							| 
									
										
										
										
											2009-03-26 12:53:39 +00:00
										 |  |  |                             , errormsg => $errorMsg | 
					
						
							| 
									
										
										
										
											2008-11-12 11:09:21 +00:00
										 |  |  |                             }); | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                         addBuildStepOutputs($step); | 
					
						
							| 
									
										
										
										
											2008-11-12 11:09:21 +00:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |                 }); | 
					
						
							| 
									
										
										
										
											2013-05-03 18:30:13 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 # Immediately fail all builds that depend on this derivation. | 
					
						
							|  |  |  |                 failDependents($drvPathStep, $errorMsg); | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2008-11-12 13:00:56 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             elsif (/^@\s+substituter-started\s+(\S+)\s+(\S+)$/) { | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                 my $path = $1; | 
					
						
							| 
									
										
										
										
											2009-04-22 22:43:04 +00:00
										 |  |  |                 txn_do($db, sub { | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                     my $step = $build->buildsteps->create( | 
					
						
							|  |  |  |                         { stepnr => ($buildSteps{$path} = $buildStepNr++) | 
					
						
							| 
									
										
										
										
											2008-11-12 13:00:56 +00:00
										 |  |  |                         , type => 1 # = substitution | 
					
						
							|  |  |  |                         , busy => 1 | 
					
						
							|  |  |  |                         , starttime => time | 
					
						
							|  |  |  |                         }); | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                     # "out" is kinda fake (substitutions don't have named outputs). | 
					
						
							|  |  |  |                     $step->buildstepoutputs->create({ name => "out", path => $path }); | 
					
						
							| 
									
										
										
										
											2008-11-12 13:00:56 +00:00
										 |  |  |                 }); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             elsif (/^@\s+substituter-succeeded\s+(\S+)$/) { | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                 my $path = $1; | 
					
						
							| 
									
										
										
										
											2009-04-22 22:43:04 +00:00
										 |  |  |                 txn_do($db, sub { | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                     my $step = $build->buildsteps->find({stepnr => $buildSteps{$path}}) or die; | 
					
						
							| 
									
										
										
										
											2009-03-09 16:22:41 +00:00
										 |  |  |                     $step->update({busy => 0, status => 0, stoptime => time}); | 
					
						
							| 
									
										
										
										
											2008-11-12 13:00:56 +00:00
										 |  |  |                 }); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             elsif (/^@\s+substituter-failed\s+(\S+)\s+(\S+)\s+(\S+)$/) { | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                 my $path = $1; | 
					
						
							| 
									
										
										
										
											2009-04-22 22:43:04 +00:00
										 |  |  |                 txn_do($db, sub { | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |                     my $step = $build->buildsteps->find({stepnr => $buildSteps{$path}}) or die; | 
					
						
							| 
									
										
										
										
											2009-03-09 16:22:41 +00:00
										 |  |  |                     $step->update({busy => 0, status => 1, errormsg => $3, stoptime => time}); | 
					
						
							| 
									
										
										
										
											2008-11-12 13:00:56 +00:00
										 |  |  |                 }); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             else { | 
					
						
							|  |  |  |                 print STDERR "unknown Nix trace message: $_"; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-06-26 12:00:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  |         close OUT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         my $res = $?; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $stopTime = time(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  |         if ($res != 0) { | 
					
						
							| 
									
										
										
										
											2012-04-30 17:57:13 +02:00
										 |  |  |             if ($thisBuildFailed && $res == 100 << 8) { $buildStatus = 1; } | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  |             elsif ($someBuildFailed) { $buildStatus = 2; } | 
					
						
							|  |  |  |             else { $buildStatus = 3; } | 
					
						
							| 
									
										
										
										
											2012-04-14 18:17:35 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  |         # Only store the output of running Nix if we have a miscellaneous error. | 
					
						
							|  |  |  |         $errormsg = undef unless $buildStatus == 3; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-09 17:21:10 +00:00
										 |  |  |   done: | 
					
						
							| 
									
										
										
										
											2010-11-19 15:44:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |     txn_do($db, sub { | 
					
						
							|  |  |  |         if ($buildStatus == 0) { | 
					
						
							| 
									
										
										
										
											2010-11-19 15:44:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |             my $size = 0; | 
					
						
							|  |  |  |             my $closureSize = 0; | 
					
						
							|  |  |  |             my $releaseName; | 
					
						
							| 
									
										
										
										
											2009-03-09 17:21:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |             my @closure = computeFSClosure(0, 0, values %outputs); | 
					
						
							|  |  |  |             foreach my $path (@closure) { | 
					
						
							|  |  |  |                 my ($deriver, $hash, $time, $narSize, $refs) = queryPathInfo($path, 0); | 
					
						
							|  |  |  |                 $closureSize += $narSize; | 
					
						
							|  |  |  |                 $size += $narSize if grep { $path eq $_ } values(%outputs); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2012-06-26 12:00:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-13 16:49:28 +00:00
										 |  |  |             foreach my $path (values %outputs) { | 
					
						
							|  |  |  |                 $buildStatus = 6 if $buildStatus == 0 && -f "$path/nix-support/failed"; | 
					
						
							|  |  |  |                 $releaseName //= getReleaseName($path); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $build->update( | 
					
						
							|  |  |  |                 { releasename => $releaseName | 
					
						
							|  |  |  |                 , size => $size | 
					
						
							|  |  |  |                 , closuresize => $closureSize | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             addBuildProducts($db, $build); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-03-05 21:52:47 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $build->update( | 
					
						
							|  |  |  |             { finished => 1 | 
					
						
							|  |  |  |             , busy => 0 | 
					
						
							|  |  |  |             , locker => '' | 
					
						
							|  |  |  |             , logfile => '' | 
					
						
							|  |  |  |             , timestamp => time # !!! Why change the timestamp? | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  |             , iscachedbuild => $isCachedBuild | 
					
						
							|  |  |  |             , buildstatus => $buildStatus | 
					
						
							|  |  |  |             , starttime => $startTime | 
					
						
							|  |  |  |             , stoptime => $stopTime | 
					
						
							| 
									
										
										
										
											2008-11-25 00:38:16 +00:00
										 |  |  |             , errormsg => $errormsg | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2009-07-07 16:15:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-08 17:54:29 +02:00
										 |  |  |     notify($build, []); | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-30 17:32:50 +01:00
										 |  |  | my $buildId = $ARGV[0] or die "syntax: $0 BUILD-ID\n"; | 
					
						
							| 
									
										
										
										
											2008-11-11 17:49:50 +00:00
										 |  |  | print STDERR "performing build $buildId\n"; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-08 15:52:55 +00:00
										 |  |  | if ($ENV{'HYDRA_MAIL_TEST'}) { | 
					
						
							| 
									
										
										
										
											2013-05-08 17:30:30 +02:00
										 |  |  |     my $build = $db->resultset('Builds')->find($buildId); | 
					
						
							| 
									
										
										
										
											2013-05-08 17:54:29 +02:00
										 |  |  |     notify($build, []); | 
					
						
							| 
									
										
										
										
											2009-10-15 13:23:15 +00:00
										 |  |  |     exit 0; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-07-07 16:15:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 12:54:37 +00:00
										 |  |  | # Lock the build.  If necessary, steal the lock from the parent | 
					
						
							|  |  |  | # process (runner.pl).  This is so that if the runner dies, the | 
					
						
							|  |  |  | # children (i.e. the build.pl instances) can continue to run and won't | 
					
						
							|  |  |  | # have the lock taken away. | 
					
						
							|  |  |  | my $build; | 
					
						
							| 
									
										
										
										
											2009-04-22 22:43:04 +00:00
										 |  |  | txn_do($db, sub { | 
					
						
							| 
									
										
										
										
											2008-11-27 15:16:06 +00:00
										 |  |  |     $build = $db->resultset('Builds')->find($buildId); | 
					
						
							| 
									
										
										
										
											2013-01-22 13:19:28 +01:00
										 |  |  |     die "build $buildId doesn't exist\n" unless defined $build; | 
					
						
							|  |  |  |     die "build $buildId already done\n" if $build->finished; | 
					
						
							| 
									
										
										
										
											2012-02-29 02:22:49 +01:00
										 |  |  |     if ($build->busy != 0 && $build->locker != getppid) { | 
					
						
							| 
									
										
										
										
											2008-11-11 12:54:37 +00:00
										 |  |  |         die "build $buildId is already being built"; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-02-29 02:22:49 +01:00
										 |  |  |     $build->update({busy => 1, locker => $$}); | 
					
						
							| 
									
										
										
										
											2009-03-16 16:56:47 +00:00
										 |  |  |     $build->buildsteps->search({busy => 1})->delete_all; | 
					
						
							| 
									
										
										
										
											2009-03-06 13:34:53 +00:00
										 |  |  |     $build->buildproducts->delete_all; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 12:54:37 +00:00
										 |  |  | die unless $build; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-11 12:54:37 +00:00
										 |  |  | # Do the build.  If it throws an error, unlock the build so that it | 
					
						
							|  |  |  | # can be retried. | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | eval { | 
					
						
							| 
									
										
										
										
											2008-11-11 12:54:37 +00:00
										 |  |  |     doBuild $build; | 
					
						
							| 
									
										
										
										
											2008-11-12 14:29:32 +00:00
										 |  |  |     print "done\n"; | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | if ($@) { | 
					
						
							|  |  |  |     warn $@; | 
					
						
							| 
									
										
										
										
											2009-04-22 22:43:04 +00:00
										 |  |  |     txn_do($db, sub { | 
					
						
							| 
									
										
										
										
											2012-02-29 02:22:49 +01:00
										 |  |  |         $build->update({busy => 0, locker => $$}); | 
					
						
							| 
									
										
										
										
											2008-11-10 13:33:12 +00:00
										 |  |  |     }); | 
					
						
							|  |  |  | } |