forked from lix-project/hydra
Move tests for SCM inputs in to its own .t
This commit is contained in:
parent
c8df544046
commit
2776ae6c78
2 changed files with 118 additions and 102 deletions
|
@ -7,7 +7,7 @@ use Setup;
|
||||||
require Hydra::Schema;
|
require Hydra::Schema;
|
||||||
require Hydra::Model::DB;
|
require Hydra::Model::DB;
|
||||||
|
|
||||||
use Test::Simple tests => 60;
|
use Test::Simple tests => 8;
|
||||||
|
|
||||||
my $db = Hydra::Model::DB->new;
|
my $db = Hydra::Model::DB->new;
|
||||||
hydra_setup($db);
|
hydra_setup($db);
|
||||||
|
@ -20,109 +20,9 @@ my $jobsBaseUri = "file://".getcwd;
|
||||||
my $project = $db->resultset('Projects')->create({name => "tests", displayname => "", owner => "root"});
|
my $project = $db->resultset('Projects')->create({name => "tests", displayname => "", owner => "root"});
|
||||||
my $jobset;
|
my $jobset;
|
||||||
|
|
||||||
|
|
||||||
# Test scm inputs
|
|
||||||
my @scminputs = (
|
|
||||||
{
|
|
||||||
name => "svn",
|
|
||||||
nixexpr => "svn-input.nix",
|
|
||||||
type => "svn",
|
|
||||||
uri => "$jobsBaseUri/svn-repo",
|
|
||||||
update => getcwd . "/jobs/svn-update.sh"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name => "svn-checkout",
|
|
||||||
nixexpr => "svn-checkout-input.nix",
|
|
||||||
type => "svn-checkout",
|
|
||||||
uri => "$jobsBaseUri/svn-checkout-repo",
|
|
||||||
update => getcwd . "/jobs/svn-checkout-update.sh"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name => "git",
|
|
||||||
nixexpr => "git-input.nix",
|
|
||||||
type => "git",
|
|
||||||
uri => "$jobsBaseUri/git-repo",
|
|
||||||
update => getcwd . "/jobs/git-update.sh"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name => "git-rev",
|
|
||||||
nixexpr => "git-rev-input.nix",
|
|
||||||
type => "git",
|
|
||||||
uri => "$jobsBaseUri/git-repo 7f60df502b96fd54bbfa64dd94b56d936a407701",
|
|
||||||
update => getcwd . "/jobs/git-rev-update.sh"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name => "deepgit",
|
|
||||||
nixexpr => "deepgit-input.nix",
|
|
||||||
type => "git",
|
|
||||||
uri => "$jobsBaseUri/git-repo master 1",
|
|
||||||
update => getcwd . "/jobs/git-update.sh"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name => "bzr",
|
|
||||||
nixexpr => "bzr-input.nix",
|
|
||||||
type => "bzr",
|
|
||||||
uri => "$jobsBaseUri/bzr-repo",
|
|
||||||
update => getcwd . "/jobs/bzr-update.sh"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name => "bzr-checkout",
|
|
||||||
nixexpr => "bzr-checkout-input.nix",
|
|
||||||
type => "bzr-checkout",
|
|
||||||
uri => "$jobsBaseUri/bzr-checkout-repo",
|
|
||||||
update => getcwd . "/jobs/bzr-checkout-update.sh"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name => "hg",
|
|
||||||
nixexpr => "hg-input.nix",
|
|
||||||
type => "hg",
|
|
||||||
uri => "$jobsBaseUri/hg-repo",
|
|
||||||
update => getcwd . "/jobs/hg-update.sh"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name => "darcs",
|
|
||||||
nixexpr => "darcs-input.nix",
|
|
||||||
type => "darcs",
|
|
||||||
uri => "$jobsBaseUri/darcs-repo",
|
|
||||||
update => getcwd . "/jobs/darcs-update.sh"
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach my $scm ( @scminputs ) {
|
|
||||||
my $scmName = $scm->{"name"};
|
|
||||||
my $nixexpr = $scm->{"nixexpr"};
|
|
||||||
my $type = $scm->{"type"};
|
|
||||||
my $uri = $scm->{"uri"};
|
|
||||||
my $update = $scm->{"update"};
|
|
||||||
$jobset = createJobsetWithOneInput($scmName, $nixexpr, "src", $type, $uri);
|
|
||||||
|
|
||||||
my $state = 0;
|
|
||||||
my $q = 0;
|
|
||||||
my ($loop, $updated) = updateRepository($scmName, $update);
|
|
||||||
while($loop) {
|
|
||||||
my $c = 0;
|
|
||||||
|
|
||||||
# Verify that it can be fetched and possibly queued.
|
|
||||||
ok(evalSucceeds($jobset), "$scmName:$state.$c: Evaluating nix-expression."); $c++;
|
|
||||||
|
|
||||||
# Verify that the evaluation has queued a new job and evaluate again to ...
|
|
||||||
if ($updated) {
|
|
||||||
$q++;
|
|
||||||
ok(nrQueuedBuildsForJobset($jobset) == $q, "$scmName:$state.$c: Expect $q jobs in the queue."); $c++;
|
|
||||||
ok(evalSucceeds($jobset), "$scmName:$state.$c: Evaluating nix-expression again."); $c++;
|
|
||||||
}
|
|
||||||
|
|
||||||
# ... check that it is deterministic and not queued again.
|
|
||||||
ok(nrQueuedBuildsForJobset($jobset) == $q, "$scmName:$state.$c: Expect $q jobs in the queue."); $c++;
|
|
||||||
|
|
||||||
$state++;
|
|
||||||
($loop, $updated) = updateRepository($scmName, $update, getcwd . "/$scmName-repo/");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
# Test build products
|
# Test build products
|
||||||
|
|
||||||
$jobset = createBaseJobset("build-products", "build-products.nix");
|
my $jobset = createBaseJobset("build-products", "build-products.nix");
|
||||||
|
|
||||||
ok(evalSucceeds($jobset), "Evaluating jobs/build-products.nix should exit with return code 0");
|
ok(evalSucceeds($jobset), "Evaluating jobs/build-products.nix should exit with return code 0");
|
||||||
ok(nrQueuedBuildsForJobset($jobset) == 2 , "Evaluating jobs/build-products.nix should result in 2 builds");
|
ok(nrQueuedBuildsForJobset($jobset) == 2 , "Evaluating jobs/build-products.nix should result in 2 builds");
|
||||||
|
|
116
tests/input-types.t
Normal file
116
tests/input-types.t
Normal file
|
@ -0,0 +1,116 @@
|
||||||
|
use strict;
|
||||||
|
use Cwd;
|
||||||
|
use Setup;
|
||||||
|
|
||||||
|
(my $datadir, my $pgsql) = test_init();
|
||||||
|
|
||||||
|
require Hydra::Schema;
|
||||||
|
require Hydra::Model::DB;
|
||||||
|
|
||||||
|
use Test2::V0;
|
||||||
|
|
||||||
|
my $db = Hydra::Model::DB->new;
|
||||||
|
hydra_setup($db);
|
||||||
|
|
||||||
|
my $jobsBaseUri = "file://".getcwd;
|
||||||
|
|
||||||
|
# Test scm inputs
|
||||||
|
my @scminputs = (
|
||||||
|
{
|
||||||
|
name => "svn",
|
||||||
|
nixexpr => "svn-input.nix",
|
||||||
|
type => "svn",
|
||||||
|
uri => "$jobsBaseUri/svn-repo",
|
||||||
|
update => getcwd . "/jobs/svn-update.sh"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name => "svn-checkout",
|
||||||
|
nixexpr => "svn-checkout-input.nix",
|
||||||
|
type => "svn-checkout",
|
||||||
|
uri => "$jobsBaseUri/svn-checkout-repo",
|
||||||
|
update => getcwd . "/jobs/svn-checkout-update.sh"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name => "git",
|
||||||
|
nixexpr => "git-input.nix",
|
||||||
|
type => "git",
|
||||||
|
uri => "$jobsBaseUri/git-repo",
|
||||||
|
update => getcwd . "/jobs/git-update.sh"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name => "git-rev",
|
||||||
|
nixexpr => "git-rev-input.nix",
|
||||||
|
type => "git",
|
||||||
|
uri => "$jobsBaseUri/git-repo 7f60df502b96fd54bbfa64dd94b56d936a407701",
|
||||||
|
update => getcwd . "/jobs/git-rev-update.sh"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name => "deepgit",
|
||||||
|
nixexpr => "deepgit-input.nix",
|
||||||
|
type => "git",
|
||||||
|
uri => "$jobsBaseUri/git-repo master 1",
|
||||||
|
update => getcwd . "/jobs/git-update.sh"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name => "bzr",
|
||||||
|
nixexpr => "bzr-input.nix",
|
||||||
|
type => "bzr",
|
||||||
|
uri => "$jobsBaseUri/bzr-repo",
|
||||||
|
update => getcwd . "/jobs/bzr-update.sh"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name => "bzr-checkout",
|
||||||
|
nixexpr => "bzr-checkout-input.nix",
|
||||||
|
type => "bzr-checkout",
|
||||||
|
uri => "$jobsBaseUri/bzr-checkout-repo",
|
||||||
|
update => getcwd . "/jobs/bzr-checkout-update.sh"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name => "hg",
|
||||||
|
nixexpr => "hg-input.nix",
|
||||||
|
type => "hg",
|
||||||
|
uri => "$jobsBaseUri/hg-repo",
|
||||||
|
update => getcwd . "/jobs/hg-update.sh"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name => "darcs",
|
||||||
|
nixexpr => "darcs-input.nix",
|
||||||
|
type => "darcs",
|
||||||
|
uri => "$jobsBaseUri/darcs-repo",
|
||||||
|
update => getcwd . "/jobs/darcs-update.sh"
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
foreach my $scm ( @scminputs ) {
|
||||||
|
my $scmName = $scm->{"name"};
|
||||||
|
my $nixexpr = $scm->{"nixexpr"};
|
||||||
|
my $type = $scm->{"type"};
|
||||||
|
my $uri = $scm->{"uri"};
|
||||||
|
my $update = $scm->{"update"};
|
||||||
|
my $jobset = createJobsetWithOneInput($scmName, $nixexpr, "src", $type, $uri);
|
||||||
|
|
||||||
|
my $state = 0;
|
||||||
|
my $q = 0;
|
||||||
|
my ($loop, $updated) = updateRepository($scmName, $update);
|
||||||
|
while($loop) {
|
||||||
|
my $c = 0;
|
||||||
|
|
||||||
|
# Verify that it can be fetched and possibly queued.
|
||||||
|
ok(evalSucceeds($jobset), "$scmName:$state.$c: Evaluating nix-expression."); $c++;
|
||||||
|
|
||||||
|
# Verify that the evaluation has queued a new job and evaluate again to ...
|
||||||
|
if ($updated) {
|
||||||
|
$q++;
|
||||||
|
ok(nrQueuedBuildsForJobset($jobset) == $q, "$scmName:$state.$c: Expect $q jobs in the queue."); $c++;
|
||||||
|
ok(evalSucceeds($jobset), "$scmName:$state.$c: Evaluating nix-expression again."); $c++;
|
||||||
|
}
|
||||||
|
|
||||||
|
# ... check that it is deterministic and not queued again.
|
||||||
|
ok(nrQueuedBuildsForJobset($jobset) == $q, "$scmName:$state.$c: Expect $q jobs in the queue."); $c++;
|
||||||
|
|
||||||
|
$state++;
|
||||||
|
($loop, $updated) = updateRepository($scmName, $update, getcwd . "/$scmName-repo/");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
done_testing;
|
Loading…
Reference in a new issue