2021-12-08 21:03:43 +00:00
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
use Setup;
|
|
|
|
use Test2::V0;
|
|
|
|
use Hydra::Plugin::RunCommand;
|
|
|
|
|
2021-12-15 02:39:13 +00:00
|
|
|
my $ctx = test_context();
|
2021-12-08 21:03:43 +00:00
|
|
|
|
2021-12-15 02:39:13 +00:00
|
|
|
my $builds = $ctx->makeAndEvaluateJobset(
|
|
|
|
expression => "runcommand-dynamic.nix",
|
|
|
|
build => 1
|
|
|
|
);
|
2021-12-08 21:03:43 +00:00
|
|
|
|
2021-12-15 02:39:13 +00:00
|
|
|
my $build = $builds->{"runCommandHook.example"};
|
2021-12-08 21:03:43 +00:00
|
|
|
|
|
|
|
is($build->job, "runCommandHook.example", "The only job should be runCommandHook.example");
|
2021-12-15 02:39:13 +00:00
|
|
|
is($build->finished, 1, "Build should be finished.");
|
|
|
|
is($build->buildstatus, 0, "Build should have buildstatus 0.");
|
2021-12-08 21:03:43 +00:00
|
|
|
|
|
|
|
subtest "fanoutToCommands" => sub {
|
|
|
|
my $config = {
|
|
|
|
runcommand => [
|
|
|
|
{
|
|
|
|
job => "",
|
|
|
|
command => "foo"
|
|
|
|
},
|
|
|
|
{
|
2021-12-15 02:39:13 +00:00
|
|
|
job => "*:*:*",
|
2021-12-08 21:03:43 +00:00
|
|
|
command => "bar"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
job => "tests:basic:nomatch",
|
|
|
|
command => "baz"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
};
|
|
|
|
|
|
|
|
is(
|
|
|
|
Hydra::Plugin::RunCommand::fanoutToCommands(
|
|
|
|
$config,
|
|
|
|
"buildFinished",
|
2021-12-15 02:39:13 +00:00
|
|
|
$build
|
2021-12-08 21:03:43 +00:00
|
|
|
),
|
|
|
|
[
|
|
|
|
{
|
|
|
|
matcher => "",
|
|
|
|
command => "foo"
|
|
|
|
},
|
|
|
|
{
|
2021-12-15 02:39:13 +00:00
|
|
|
matcher => "*:*:*",
|
2021-12-08 21:03:43 +00:00
|
|
|
command => "bar"
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"fanoutToCommands returns a command per matching job"
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
subtest "fanoutToCommandsWithDynamicRunCommandSupport" => sub {
|
|
|
|
like(
|
|
|
|
$build->buildoutputs->find({name => "out"})->path,
|
|
|
|
qr/my-build-product$/,
|
|
|
|
"The way we find the out path is reasonable"
|
|
|
|
);
|
|
|
|
|
|
|
|
my $config = {
|
|
|
|
dynamicruncommand => { enable => 1 },
|
|
|
|
runcommand => [
|
|
|
|
{
|
2021-12-15 02:39:13 +00:00
|
|
|
job => "*:*:*",
|
2021-12-08 21:03:43 +00:00
|
|
|
command => "baz"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
};
|
|
|
|
|
|
|
|
is(
|
|
|
|
Hydra::Plugin::RunCommand::fanoutToCommands(
|
|
|
|
$config,
|
|
|
|
"buildFinished",
|
|
|
|
$build
|
|
|
|
),
|
|
|
|
[
|
|
|
|
{
|
2021-12-15 02:39:13 +00:00
|
|
|
matcher => "*:*:*",
|
2021-12-08 21:03:43 +00:00
|
|
|
command => "baz"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
matcher => "DynamicRunCommand(runCommandHook.example)",
|
|
|
|
command => $build->buildoutputs->find({name => "out"})->path
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"fanoutToCommands returns a command per matching job"
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2021-12-14 21:31:19 +00:00
|
|
|
subtest "isBuildEligibleForDynamicRunCommand" => sub {
|
|
|
|
my $build = Hydra::Schema::Result::Builds->new({
|
|
|
|
"job" => "foo bar baz"
|
|
|
|
});
|
|
|
|
|
|
|
|
is(
|
|
|
|
Hydra::Plugin::RunCommand::isBuildEligibleForDynamicRunCommand($build),
|
|
|
|
0,
|
|
|
|
"The job name does not match"
|
|
|
|
);
|
|
|
|
|
|
|
|
$build->set_column("job", "runCommandHook");
|
|
|
|
is(
|
|
|
|
Hydra::Plugin::RunCommand::isBuildEligibleForDynamicRunCommand($build),
|
|
|
|
0,
|
|
|
|
"The job name does not match"
|
|
|
|
);
|
|
|
|
|
|
|
|
$build->set_column("job", "runCommandHook.");
|
|
|
|
is(
|
|
|
|
Hydra::Plugin::RunCommand::isBuildEligibleForDynamicRunCommand($build),
|
|
|
|
0,
|
|
|
|
"The job name does not match"
|
|
|
|
);
|
|
|
|
|
|
|
|
$build->set_column("job", "runCommandHook.a");
|
|
|
|
is(
|
|
|
|
Hydra::Plugin::RunCommand::isBuildEligibleForDynamicRunCommand($build),
|
|
|
|
1,
|
|
|
|
"The job name does match"
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2021-12-08 21:03:43 +00:00
|
|
|
done_testing;
|