51 lines
1.7 KiB
Perl
51 lines
1.7 KiB
Perl
|
use warnings;
|
||
|
use strict;
|
||
|
|
||
|
package CliRunners;
|
||
|
our @ISA = qw(Exporter);
|
||
|
our @EXPORT = qw(
|
||
|
evalSucceeds runBuild sendNotifications
|
||
|
captureStdoutStderr);
|
||
|
|
||
|
|
||
|
sub captureStdoutStderr {
|
||
|
# "Lazy"-load Hydra::Helper::Nix to avoid the compile-time
|
||
|
# import of Hydra::Model::DB. Early loading of the DB class
|
||
|
# causes fixation of the DSN, and we need to fixate it after
|
||
|
# the temporary DB is setup.
|
||
|
require Hydra::Helper::Nix;
|
||
|
return Hydra::Helper::Nix::captureStdoutStderr(@_)
|
||
|
}
|
||
|
|
||
|
sub evalSucceeds {
|
||
|
my ($jobset) = @_;
|
||
|
my ($res, $stdout, $stderr) = captureStdoutStderr(60, ("hydra-eval-jobset", $jobset->project->name, $jobset->name));
|
||
|
$jobset->discard_changes; # refresh from DB
|
||
|
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 "";
|
||
|
return !$res;
|
||
|
}
|
||
|
|
||
|
sub runBuild {
|
||
|
my ($build) = @_;
|
||
|
my ($res, $stdout, $stderr) = captureStdoutStderr(60, ("hydra-queue-runner", "-vvvv", "--build-one", $build->id));
|
||
|
if ($res) {
|
||
|
print STDERR "Queue runner stdout: $stdout\n" if $stdout ne "";
|
||
|
print STDERR "Queue runner stderr: $stderr\n" if $stderr ne "";
|
||
|
}
|
||
|
return !$res;
|
||
|
}
|
||
|
|
||
|
sub sendNotifications() {
|
||
|
my ($res, $stdout, $stderr) = captureStdoutStderr(60, ("hydra-notify", "--queued-only"));
|
||
|
if ($res) {
|
||
|
print STDERR "hydra notify stdout: $stdout\n" if $stdout ne "";
|
||
|
print STDERR "hydra notify stderr: $stderr\n" if $stderr ne "";
|
||
|
}
|
||
|
return !$res;
|
||
|
}
|
||
|
|
||
|
1;
|