2011-03-16 13:18:12 +00:00
|
|
|
package Setup;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use Exporter;
|
2011-03-17 13:25:27 +00:00
|
|
|
use Hydra::Helper::Nix;
|
2012-03-13 12:18:40 +00:00
|
|
|
use Hydra::Model::DB;
|
2011-03-17 13:25:27 +00:00
|
|
|
use Hydra::Helper::AddBuilds;
|
|
|
|
use Cwd;
|
2011-03-16 13:18:12 +00:00
|
|
|
|
|
|
|
our @ISA = qw(Exporter);
|
2012-04-15 01:17:35 +00:00
|
|
|
our @EXPORT = qw(hydra_setup nrBuildsForJobset queuedBuildsForJobset nrQueuedBuildsForJobset createBaseJobset createJobsetWithOneInput evalSucceeds runBuild updateRepository);
|
2011-03-16 13:18:12 +00:00
|
|
|
|
|
|
|
sub hydra_setup {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($db) = @_;
|
2013-03-04 14:25:23 +00:00
|
|
|
$db->resultset('Users')->create({ username => "root", emailaddress => 'root@invalid.org', password => '' });
|
2011-03-16 13:18:12 +00:00
|
|
|
}
|
|
|
|
|
2011-03-17 11:55:39 +00:00
|
|
|
sub nrBuildsForJobset {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($jobset) = @_;
|
|
|
|
return $jobset->builds->search({},{})->count ;
|
2011-03-17 11:55:39 +00:00
|
|
|
}
|
|
|
|
|
2011-03-17 13:25:27 +00:00
|
|
|
sub queuedBuildsForJobset {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($jobset) = @_;
|
|
|
|
return $jobset->builds->search({finished => 0});
|
2011-03-17 13:25:27 +00:00
|
|
|
}
|
|
|
|
|
2011-03-17 11:55:39 +00:00
|
|
|
sub nrQueuedBuildsForJobset {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($jobset) = @_;
|
|
|
|
return queuedBuildsForJobset($jobset)->count ;
|
2011-03-17 11:55:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sub createBaseJobset {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($jobsetName, $nixexprpath) = @_;
|
2013-01-22 13:41:02 +00:00
|
|
|
|
2013-01-23 12:49:26 +00:00
|
|
|
my $db = Hydra::Model::DB->new;
|
|
|
|
my $project = $db->resultset('Projects')->update_or_create({name => "tests", displayname => "", owner => "root"});
|
|
|
|
my $jobset = $project->jobsets->create({name => $jobsetName, nixexprinput => "jobs", nixexprpath => $nixexprpath, emailoverride => ""});
|
2011-03-17 11:55:39 +00:00
|
|
|
|
2013-01-23 12:49:26 +00:00
|
|
|
my $jobsetinput;
|
|
|
|
my $jobsetinputals;
|
2011-03-17 11:55:39 +00:00
|
|
|
|
2013-01-23 12:49:26 +00:00
|
|
|
$jobsetinput = $jobset->jobsetinputs->create({name => "jobs", type => "path"});
|
|
|
|
$jobsetinputals = $jobsetinput->jobsetinputalts->create({altnr => 0, value => getcwd."/jobs"});
|
2011-03-17 11:55:39 +00:00
|
|
|
|
2013-01-23 12:49:26 +00:00
|
|
|
return $jobset;
|
2011-03-17 11:55:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sub createJobsetWithOneInput {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($jobsetName, $nixexprpath, $name, $type, $uri) = @_;
|
|
|
|
my $jobset = createBaseJobset($jobsetName, $nixexprpath);
|
2011-03-17 11:55:39 +00:00
|
|
|
|
2013-01-23 12:49:26 +00:00
|
|
|
my $jobsetinput;
|
|
|
|
my $jobsetinputals;
|
2011-03-17 11:55:39 +00:00
|
|
|
|
2013-01-23 12:49:26 +00:00
|
|
|
$jobsetinput = $jobset->jobsetinputs->create({name => $name, type => $type});
|
|
|
|
$jobsetinputals = $jobsetinput->jobsetinputalts->create({altnr => 0, value => $uri});
|
2011-03-17 11:55:39 +00:00
|
|
|
|
2013-01-23 12:49:26 +00:00
|
|
|
return $jobset;
|
2011-03-17 11:55:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sub evalSucceeds {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($jobset) = @_;
|
2016-10-13 13:53:05 +00:00
|
|
|
my ($res, $stdout, $stderr) = captureStdoutStderr(60, ("hydra-eval-jobset", $jobset->project->name, $jobset->name));
|
2013-01-23 12:49:26 +00:00
|
|
|
chomp $stdout; chomp $stderr;
|
|
|
|
print STDERR "Evaluation errors for jobset ".$jobset->project->name.":".$jobset->name.": \n".$jobset->errormsg."\n" if $jobset->errormsg;
|
|
|
|
print STDERR "STDOUT: $stdout\n" if $stdout ne "";
|
|
|
|
print STDERR "STDERR: $stderr\n" if $stderr ne "";
|
2013-01-23 14:56:28 +00:00
|
|
|
return !$res;
|
2011-03-17 11:55:39 +00:00
|
|
|
}
|
|
|
|
|
2011-03-17 13:25:27 +00:00
|
|
|
sub runBuild {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($build) = @_;
|
2015-06-25 13:29:22 +00:00
|
|
|
my ($res, $stdout, $stderr) = captureStdoutStderr(60, ("hydra-queue-runner", "-vvvv", "--build-one", $build->id));
|
2016-10-06 15:18:10 +00:00
|
|
|
if ($res) {
|
|
|
|
print STDERR "Queue runner stdout: $stdout\n" if $stdout ne "";
|
|
|
|
print STDERR "Queue runner stderr: $stderr\n" if $stderr ne "";
|
|
|
|
}
|
2013-01-23 14:56:28 +00:00
|
|
|
return !$res;
|
2011-03-17 13:25:27 +00:00
|
|
|
}
|
|
|
|
|
2012-04-15 01:17:35 +00:00
|
|
|
sub updateRepository {
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($scm, $update) = @_;
|
|
|
|
my ($res, $stdout, $stderr) = captureStdoutStderr(60, ($update, $scm));
|
2013-01-23 14:56:28 +00:00
|
|
|
die "unexpected update error with $scm: $stderr\n" if $res;
|
2013-01-23 12:49:26 +00:00
|
|
|
my ($message, $loop, $status) = $stdout =~ m/::(.*) -- (.*) -- (.*)::/;
|
|
|
|
print STDOUT "Update $scm repository: $message\n";
|
|
|
|
return ($loop eq "continue", $status eq "updated");
|
2012-04-15 01:17:35 +00:00
|
|
|
}
|
|
|
|
|
2011-03-16 13:18:12 +00:00
|
|
|
1;
|