Merge pull request #1230 from helsinki-systems/fix/declarative-dynamic-runcommand
AddBuilds: fix declarative jobsets with dynamic runcommand enabled
This commit is contained in:
commit
f2f82b3eee
3 changed files with 59 additions and 15 deletions
|
@ -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.";
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
),
|
),
|
||||||
|
|
|
@ -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)
|
||||||
),
|
),
|
||||||
|
|
Loading…
Reference in a new issue