AddBuilds: fix declarative jobsets with dynamic runcommand enabled

$project->{enable_dynamic_run_command} is undefined
This commit is contained in:
ajs124 2022-06-30 00:32:31 +02:00
parent 44841fc827
commit bb1f04ed86
3 changed files with 59 additions and 15 deletions

View file

@ -67,7 +67,7 @@ sub validateDeclarativeJobset {
my $enable_dynamic_run_command = defined $update{enable_dynamic_run_command} ? 1 : 0; my $enable_dynamic_run_command = defined $update{enable_dynamic_run_command} ? 1 : 0;
if ($enable_dynamic_run_command if ($enable_dynamic_run_command
&& !($config->{dynamicruncommand}->{enable} && !($config->{dynamicruncommand}->{enable}
&& $project->{enable_dynamic_run_command})) && $project->enable_dynamic_run_command))
{ {
die "Dynamic RunCommand is not enabled by the server or the parent project."; die "Dynamic RunCommand is not enabled by the server or the parent project.";
} }

View file

@ -6,11 +6,31 @@ use Test2::V0;
require Catalyst::Test; require Catalyst::Test;
use HTTP::Request::Common qw(POST PUT GET DELETE); use HTTP::Request::Common qw(POST PUT GET DELETE);
use JSON::MaybeXS qw(decode_json encode_json); use JSON::MaybeXS qw(decode_json encode_json);
use Hydra::Helper::AddBuilds qw(validateDeclarativeJobset);
use Hydra::Helper::Nix qw(getHydraConfig);
my $ctx = test_context(); my $ctx = test_context();
Catalyst::Test->import('Hydra');
my $db = Hydra::Model::DB->new;
hydra_setup($db);
my $user = $db->resultset('Users')->create({ username => 'alice', emailaddress => 'root@invalid.org', password => '!' });
$user->setPassword('foobar');
$user->userroles->update_or_create({ role => 'admin' });
my $project_with_dynamic_run_command = $db->resultset('Projects')->create({
name => 'tests_with_dynamic_runcommand',
displayname => 'Tests with dynamic runcommand',
owner => 'alice',
enable_dynamic_run_command => 1,
});
my $project_without_dynamic_run_command = $db->resultset('Projects')->create({
name => 'tests_without_dynamic_runcommand',
displayname => 'Tests without dynamic runcommand',
owner => 'alice',
enable_dynamic_run_command => 0,
});
sub makeJobsetSpec { sub makeJobsetSpec {
my ($dynamic) = @_; my ($dynamic) = @_;
@ -29,14 +49,16 @@ sub makeJobsetSpec {
}; };
subtest "validate declarative jobset with dynamic RunCommand disabled by server" => sub { subtest "validate declarative jobset with dynamic RunCommand disabled by server" => sub {
my $config = getHydraConfig(); my $config = Hydra::Helper::Nix->getHydraConfig();
require Hydra::Helper::AddBuilds;
Hydra::Helper::AddBuilds->import( qw(validateDeclarativeJobset) );
subtest "project enabled dynamic runcommand, declarative jobset enabled dynamic runcommand" => sub { subtest "project enabled dynamic runcommand, declarative jobset enabled dynamic runcommand" => sub {
like( like(
dies { dies {
validateDeclarativeJobset( validateDeclarativeJobset(
$config, $config,
{ enable_dynamic_run_command => 1 }, $project_with_dynamic_run_command,
"test-jobset", "test-jobset",
makeJobsetSpec(JSON::MaybeXS::true), makeJobsetSpec(JSON::MaybeXS::true),
), ),
@ -49,7 +71,7 @@ subtest "validate declarative jobset with dynamic RunCommand disabled by server"
ok( ok(
validateDeclarativeJobset( validateDeclarativeJobset(
$config, $config,
{ enable_dynamic_run_command => 1 }, $project_with_dynamic_run_command,
"test-jobset", "test-jobset",
makeJobsetSpec(JSON::MaybeXS::false) makeJobsetSpec(JSON::MaybeXS::false)
), ),
@ -61,7 +83,7 @@ subtest "validate declarative jobset with dynamic RunCommand disabled by server"
dies { dies {
validateDeclarativeJobset( validateDeclarativeJobset(
$config, $config,
{ enable_dynamic_run_command => 0 }, $project_without_dynamic_run_command,
"test-jobset", "test-jobset",
makeJobsetSpec(JSON::MaybeXS::true), makeJobsetSpec(JSON::MaybeXS::true),
), ),
@ -74,7 +96,7 @@ subtest "validate declarative jobset with dynamic RunCommand disabled by server"
ok( ok(
validateDeclarativeJobset( validateDeclarativeJobset(
$config, $config,
{ enable_dynamic_run_command => 0 }, $project_without_dynamic_run_command,
"test-jobset", "test-jobset",
makeJobsetSpec(JSON::MaybeXS::false) makeJobsetSpec(JSON::MaybeXS::false)
), ),

View file

@ -6,8 +6,6 @@ use Test2::V0;
require Catalyst::Test; require Catalyst::Test;
use HTTP::Request::Common qw(POST PUT GET DELETE); use HTTP::Request::Common qw(POST PUT GET DELETE);
use JSON::MaybeXS qw(decode_json encode_json); use JSON::MaybeXS qw(decode_json encode_json);
use Hydra::Helper::AddBuilds qw(validateDeclarativeJobset);
use Hydra::Helper::Nix qw(getHydraConfig);
my $ctx = test_context( my $ctx = test_context(
hydra_config => q| hydra_config => q|
@ -17,6 +15,28 @@ my $ctx = test_context(
| |
); );
Catalyst::Test->import('Hydra');
my $db = Hydra::Model::DB->new;
hydra_setup($db);
my $user = $db->resultset('Users')->create({ username => 'alice', emailaddress => 'root@invalid.org', password => '!' });
$user->setPassword('foobar');
$user->userroles->update_or_create({ role => 'admin' });
my $project_with_dynamic_run_command = $db->resultset('Projects')->create({
name => 'tests_with_dynamic_runcommand',
displayname => 'Tests with dynamic runcommand',
owner => 'alice',
enable_dynamic_run_command => 1,
});
my $project_without_dynamic_run_command = $db->resultset('Projects')->create({
name => 'tests_without_dynamic_runcommand',
displayname => 'Tests without dynamic runcommand',
owner => 'alice',
enable_dynamic_run_command => 0,
});
sub makeJobsetSpec { sub makeJobsetSpec {
my ($dynamic) = @_; my ($dynamic) = @_;
@ -35,13 +55,15 @@ sub makeJobsetSpec {
}; };
subtest "validate declarative jobset with dynamic RunCommand enabled by server" => sub { subtest "validate declarative jobset with dynamic RunCommand enabled by server" => sub {
my $config = getHydraConfig(); my $config = Hydra::Helper::Nix->getHydraConfig();
require Hydra::Helper::AddBuilds;
Hydra::Helper::AddBuilds->import( qw(validateDeclarativeJobset) );
subtest "project enabled dynamic runcommand, declarative jobset enabled dynamic runcommand" => sub { subtest "project enabled dynamic runcommand, declarative jobset enabled dynamic runcommand" => sub {
ok( ok(
validateDeclarativeJobset( validateDeclarativeJobset(
$config, $config,
{ enable_dynamic_run_command => 1 }, $project_with_dynamic_run_command,
"test-jobset", "test-jobset",
makeJobsetSpec(JSON::MaybeXS::true) makeJobsetSpec(JSON::MaybeXS::true)
), ),
@ -52,7 +74,7 @@ subtest "validate declarative jobset with dynamic RunCommand enabled by server"
ok( ok(
validateDeclarativeJobset( validateDeclarativeJobset(
$config, $config,
{ enable_dynamic_run_command => 1 }, $project_with_dynamic_run_command,
"test-jobset", "test-jobset",
makeJobsetSpec(JSON::MaybeXS::false) makeJobsetSpec(JSON::MaybeXS::false)
), ),
@ -64,7 +86,7 @@ subtest "validate declarative jobset with dynamic RunCommand enabled by server"
dies { dies {
validateDeclarativeJobset( validateDeclarativeJobset(
$config, $config,
{ enable_dynamic_run_command => 0 }, $project_without_dynamic_run_command,
"test-jobset", "test-jobset",
makeJobsetSpec(JSON::MaybeXS::true), makeJobsetSpec(JSON::MaybeXS::true),
), ),
@ -77,7 +99,7 @@ subtest "validate declarative jobset with dynamic RunCommand enabled by server"
ok( ok(
validateDeclarativeJobset( validateDeclarativeJobset(
$config, $config,
{ enable_dynamic_run_command => 0 }, $project_without_dynamic_run_command,
"test-jobset", "test-jobset",
makeJobsetSpec(JSON::MaybeXS::false) makeJobsetSpec(JSON::MaybeXS::false)
), ),