Makes it so HydraTestContext can call them without an import loop
LEW5O57PMQ4SMFWYFWJ22R3IFJ63RPV5FMPEAGW3JRZCDJCR5WNAC MIQH5W3F2WJKYDFYAFVI7OUXWZOPYXSO7HCGCHRA2MBTV7POCR6QC YIZWKGFIITUYV2TW5RGMXY4IGHHIKHJWJ3ZG53LWW3GBYHR4LW4QC HXEZUCTD7T3YUT3XKWQOWRFSADNFZT2EYXHOATIBXWTNACDHNQQQC EAFAL4V3QNMMWBXW2JU2OZU3HUIOPIMWBIBYE4LF7S35B2SUZTZQC 2JJP76737U2JWJWQ6UDFEAQCGWRAQH46HC6OCIKWMB5QYRXF6DQQC HX4QYOYAKKFKK4KF6SZ6FQCM5ZF7ZFDTQUR4GS5WPPTYZASYZZUAC 4QI6G7YB64IPWRQYGI4D2CEEUGPSVM6MVKUA4VVRKKIEA4D34FEQC OWRS526HCBSKWK5KFWO34YSZRNRXWBBG74KLW7BZSRIIZUNSELBQC UIA3ULNUQVJJJYYVSHCT3GMNYBB5GRHEMHBU2KIFPFG6YVTLMYKAC SBKX3YH2EOCYY2IDACGOTXHJZSYSRHD5EC7FB6WGPKHLFYOF6SAAC QIW2WZKWE3ULO4O4QB6EQWUKZY2UFNN7WA464FMIZOAHP3UHFGSAC 4YCF3KBGI4VYKHJXAREJLCJLY3UWB2FX447CJ4XQWFRKRFKG5WCQC UGA45FNCYAHX77QI3MTMSRF676N2BUW2ZUUI4OZCI2C3EJOYKY3QC A43SLRSH6OIIEZWLRKLMERX7HOMBICKG7WHELCZYLOJWZ3JFRV2AC FAIJDQKZH6SUUNCKW5RIOZ37YRAO5ACS6FX76MHRNN53LDBWO6ZQC 7VQ4ALFYKJBFR46T3WZDMGOXNRR3QNJEJQVBYJM4HSJUOOUD6WBQC VI32YSGASTFSF6EKDAIGHDTH2E7YMDS532LOWEH2OYKXAD243TZAC HE3GX5IPS6XA7KLNP5WZY2YU27WQS663WSKAL5FHWBSJ5GMM633AC V2ALOFRRXCDVWOED74BORKDSVVIQHLWOC7FMUTPHORGFB6XRURMQC 3AKZKWCRQZTASQO5BZ4KCEFJ5OMP7LVF6YOPDJN5KCRIZIW75MCAC use warnings;use strict;package CliRunners;our @ISA = qw(Exporter);our @EXPORT = qw(evalSucceeds runBuild sendNotificationscaptureStdoutStderr);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 DBchomp $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;
}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 DBchomp $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;