forked from lix-project/hydra
Merge pull request #973 from DeterminateSystems/build-evals
/build/ID/evals: fix after #860
This commit is contained in:
commit
4375268276
14 changed files with 143 additions and 18 deletions
src/lib/Hydra
t
|
@ -558,7 +558,7 @@ sub evals : Chained('buildChain') PathPart('evals') Args(0) {
|
||||||
$c->stash->{page} = $page;
|
$c->stash->{page} = $page;
|
||||||
$c->stash->{resultsPerPage} = $resultsPerPage;
|
$c->stash->{resultsPerPage} = $resultsPerPage;
|
||||||
$c->stash->{total} = $evals->search({hasnewbuilds => 1})->count;
|
$c->stash->{total} = $evals->search({hasnewbuilds => 1})->count;
|
||||||
$c->stash->{evals} = getEvals($self, $c, $evals, ($page - 1) * $resultsPerPage, $resultsPerPage)
|
$c->stash->{evals} = getEvals($c, $evals, ($page - 1) * $resultsPerPage, $resultsPerPage)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,7 @@ sub jobset_GET {
|
||||||
|
|
||||||
$c->stash->{template} = 'jobset.tt';
|
$c->stash->{template} = 'jobset.tt';
|
||||||
|
|
||||||
$c->stash->{evals} = getEvals($self, $c, scalar $c->stash->{jobset}->jobsetevals, 0, 10);
|
$c->stash->{evals} = getEvals($c, scalar $c->stash->{jobset}->jobsetevals, 0, 10);
|
||||||
|
|
||||||
$c->stash->{latestEval} = $c->stash->{jobset}->jobsetevals->search({ hasnewbuilds => 1 }, { rows => 1, order_by => ["id desc"] })->single;
|
$c->stash->{latestEval} = $c->stash->{jobset}->jobsetevals->search({ hasnewbuilds => 1 }, { rows => 1, order_by => ["id desc"] })->single;
|
||||||
|
|
||||||
|
@ -337,7 +337,7 @@ sub evals_GET {
|
||||||
$c->stash->{resultsPerPage} = $resultsPerPage;
|
$c->stash->{resultsPerPage} = $resultsPerPage;
|
||||||
$c->stash->{total} = $evals->search({hasnewbuilds => 1})->count;
|
$c->stash->{total} = $evals->search({hasnewbuilds => 1})->count;
|
||||||
my $offset = ($page - 1) * $resultsPerPage;
|
my $offset = ($page - 1) * $resultsPerPage;
|
||||||
$c->stash->{evals} = getEvals($self, $c, $evals, $offset, $resultsPerPage);
|
$c->stash->{evals} = getEvals($c, $evals, $offset, $resultsPerPage);
|
||||||
my %entity = (
|
my %entity = (
|
||||||
evals => [ map { $_->{eval} } @{$c->stash->{evals}} ],
|
evals => [ map { $_->{eval} } @{$c->stash->{evals}} ],
|
||||||
first => "?page=1",
|
first => "?page=1",
|
||||||
|
|
|
@ -398,7 +398,7 @@ sub evals :Local Args(0) {
|
||||||
$c->stash->{page} = $page;
|
$c->stash->{page} = $page;
|
||||||
$c->stash->{resultsPerPage} = $resultsPerPage;
|
$c->stash->{resultsPerPage} = $resultsPerPage;
|
||||||
$c->stash->{total} = $evals->search({hasnewbuilds => 1})->count;
|
$c->stash->{total} = $evals->search({hasnewbuilds => 1})->count;
|
||||||
$c->stash->{evals} = getEvals($self, $c, $evals, ($page - 1) * $resultsPerPage, $resultsPerPage);
|
$c->stash->{evals} = getEvals($c, $evals, ($page - 1) * $resultsPerPage, $resultsPerPage);
|
||||||
|
|
||||||
$self->status_ok($c, entity => $c->stash->{evals});
|
$self->status_ok($c, entity => $c->stash->{evals});
|
||||||
}
|
}
|
||||||
|
|
|
@ -223,13 +223,42 @@ sub getEvalInfo {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sub getEvals {
|
=head2 getEvals
|
||||||
my ($self, $c, $evals, $offset, $rows) = @_;
|
|
||||||
|
|
||||||
my @evals = $evals->search(
|
This method returns a list of evaluations with details about what changed,
|
||||||
|
intended to be used with `eval.tt`.
|
||||||
|
|
||||||
|
Arguments:
|
||||||
|
|
||||||
|
=over 4
|
||||||
|
|
||||||
|
=item C<$c>
|
||||||
|
L<Hydra> - the entire application.
|
||||||
|
|
||||||
|
=item C<$evals_result_set>
|
||||||
|
|
||||||
|
A L<DBIx::Class::ResultSet> for the result class of L<Hydra::Model::DB::JobsetEvals>
|
||||||
|
|
||||||
|
=item C<$offset>
|
||||||
|
|
||||||
|
Integer offset when selecting evaluations
|
||||||
|
|
||||||
|
=item C<$rows>
|
||||||
|
|
||||||
|
Integer rows to fetch
|
||||||
|
|
||||||
|
=back
|
||||||
|
|
||||||
|
=cut
|
||||||
|
sub getEvals {
|
||||||
|
my ($c, $evals_result_set, $offset, $rows) = @_;
|
||||||
|
|
||||||
|
my $me = $evals_result_set->current_source_alias;
|
||||||
|
|
||||||
|
my @evals = $evals_result_set->search(
|
||||||
{ hasnewbuilds => 1 },
|
{ hasnewbuilds => 1 },
|
||||||
{ order_by => "me.id DESC", rows => $rows, offset => $offset
|
{ order_by => "$me.id DESC", rows => $rows, offset => $offset
|
||||||
, prefetch => { evaluationerror => [ ] } });
|
, prefetch => { evaluationerror => [ ] } });
|
||||||
my @res = ();
|
my @res = ();
|
||||||
my $cache = {};
|
my $cache = {};
|
||||||
|
|
||||||
|
|
33
t/Controller/Build/evals.t
Normal file
33
t/Controller/Build/evals.t
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
use strict;
|
||||||
|
use Setup;
|
||||||
|
use Data::Dumper;
|
||||||
|
my %ctx = test_init();
|
||||||
|
|
||||||
|
require Hydra::Schema;
|
||||||
|
require Hydra::Model::DB;
|
||||||
|
require Hydra::Helper::Nix;
|
||||||
|
|
||||||
|
use Test2::V0;
|
||||||
|
require Catalyst::Test;
|
||||||
|
use HTTP::Request::Common;
|
||||||
|
Catalyst::Test->import('Hydra');
|
||||||
|
|
||||||
|
my $db = Hydra::Model::DB->new;
|
||||||
|
hydra_setup($db);
|
||||||
|
|
||||||
|
my $project = $db->resultset('Projects')->create({name => "tests", displayname => "", owner => "root"});
|
||||||
|
|
||||||
|
my $jobset = createBaseJobset("basic", "basic.nix", $ctx{jobsdir});
|
||||||
|
|
||||||
|
ok(evalSucceeds($jobset), "Evaluating jobs/basic.nix should exit with return code 0");
|
||||||
|
is(nrQueuedBuildsForJobset($jobset), 3, "Evaluating jobs/basic.nix should result in 3 builds");
|
||||||
|
my ($build, @builds) = queuedBuildsForJobset($jobset);
|
||||||
|
|
||||||
|
ok(runBuild($build), "Build '".$build->job."' from jobs/basic.nix should exit with return code 0");
|
||||||
|
|
||||||
|
subtest "/build/ID/evals" => sub {
|
||||||
|
my $evals = request(GET '/build/' . $build->id . '/evals');
|
||||||
|
ok($evals->is_success, "The page listing evaluations this build is part of returns 200.");
|
||||||
|
};
|
||||||
|
|
||||||
|
done_testing;
|
|
@ -29,7 +29,7 @@ ok(evalSucceeds($jobset));
|
||||||
is(nrQueuedBuildsForJobset($jobset), 4);
|
is(nrQueuedBuildsForJobset($jobset), 4);
|
||||||
|
|
||||||
for my $build (queuedBuildsForJobset($jobset)) {
|
for my $build (queuedBuildsForJobset($jobset)) {
|
||||||
ok(runBuild($build), "Build '".$build->job."' should exit with code 0");
|
ok(runBuild($build), "Build '".$build->job."' should exit with return code 0");
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
is($newbuild->finished, 1, "Build '".$build->job."' should be finished.");
|
is($newbuild->finished, 1, "Build '".$build->job."' should be finished.");
|
||||||
is($newbuild->buildstatus, 0, "Build '".$build->job."' should have buildstatus 0.");
|
is($newbuild->buildstatus, 0, "Build '".$build->job."' should have buildstatus 0.");
|
||||||
|
|
34
t/Controller/Jobset/evals.t
Normal file
34
t/Controller/Jobset/evals.t
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
use strict;
|
||||||
|
use Setup;
|
||||||
|
use Data::Dumper;
|
||||||
|
my %ctx = test_init();
|
||||||
|
|
||||||
|
require Hydra::Schema;
|
||||||
|
require Hydra::Model::DB;
|
||||||
|
require Hydra::Helper::Nix;
|
||||||
|
|
||||||
|
use Test2::V0;
|
||||||
|
require Catalyst::Test;
|
||||||
|
use HTTP::Request::Common;
|
||||||
|
Catalyst::Test->import('Hydra');
|
||||||
|
|
||||||
|
my $db = Hydra::Model::DB->new;
|
||||||
|
hydra_setup($db);
|
||||||
|
|
||||||
|
my $project = $db->resultset('Projects')->create({name => "tests", displayname => "", owner => "root"});
|
||||||
|
|
||||||
|
my $jobset = createBaseJobset("basic", "basic.nix", $ctx{jobsdir});
|
||||||
|
|
||||||
|
ok(evalSucceeds($jobset), "Evaluating jobs/basic.nix should exit with return code 0");
|
||||||
|
|
||||||
|
subtest "/jobset/PROJECT/JOBSET" => sub {
|
||||||
|
my $jobset = request(GET '/jobset/' . $project->name . '/' . $jobset->name);
|
||||||
|
ok($jobset->is_success, "The page showing the jobset returns 200.");
|
||||||
|
};
|
||||||
|
|
||||||
|
subtest "/jobset/PROJECT/JOBSET/evals" => sub {
|
||||||
|
my $jobsetevals = request(GET '/jobset/' . $project->name . '/' . $jobset->name . '/evals');
|
||||||
|
ok($jobsetevals->is_success, "The page showing the jobset evals returns 200.");
|
||||||
|
};
|
||||||
|
|
||||||
|
done_testing;
|
29
t/Controller/Root/evals.t
Normal file
29
t/Controller/Root/evals.t
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
use strict;
|
||||||
|
use Setup;
|
||||||
|
use Data::Dumper;
|
||||||
|
my %ctx = test_init();
|
||||||
|
|
||||||
|
require Hydra::Schema;
|
||||||
|
require Hydra::Model::DB;
|
||||||
|
require Hydra::Helper::Nix;
|
||||||
|
|
||||||
|
use Test2::V0;
|
||||||
|
require Catalyst::Test;
|
||||||
|
use HTTP::Request::Common;
|
||||||
|
Catalyst::Test->import('Hydra');
|
||||||
|
|
||||||
|
my $db = Hydra::Model::DB->new;
|
||||||
|
hydra_setup($db);
|
||||||
|
|
||||||
|
my $project = $db->resultset('Projects')->create({name => "tests", displayname => "", owner => "root"});
|
||||||
|
|
||||||
|
my $jobset = createBaseJobset("basic", "basic.nix", $ctx{jobsdir});
|
||||||
|
|
||||||
|
ok(evalSucceeds($jobset), "Evaluating jobs/basic.nix should exit with return code 0");
|
||||||
|
|
||||||
|
subtest "/evals" => sub {
|
||||||
|
my $global = request(GET '/evals');
|
||||||
|
ok($global->is_success, "The page showing the all evals returns 200.");
|
||||||
|
};
|
||||||
|
|
||||||
|
done_testing;
|
|
@ -21,7 +21,7 @@ is(nrQueuedBuildsForJobset($jobset), 2, "Evaluating jobs/build-products.nix shou
|
||||||
|
|
||||||
for my $build (queuedBuildsForJobset($jobset)) {
|
for my $build (queuedBuildsForJobset($jobset)) {
|
||||||
subtest "For the build job '" . $build->job . "'" => sub {
|
subtest "For the build job '" . $build->job . "'" => sub {
|
||||||
ok(runBuild($build), "Build should exit with code 0");
|
ok(runBuild($build), "Build should exit with return code 0");
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
|
|
||||||
is($newbuild->finished, 1, "Build should have finished");
|
is($newbuild->finished, 1, "Build should have finished");
|
||||||
|
|
|
@ -21,7 +21,7 @@ ok(evalSucceeds($jobset), "Evaluating jobs/basic.nix should exit w
|
||||||
is(nrQueuedBuildsForJobset($jobset), 3, "Evaluating jobs/basic.nix should result in 3 builds");
|
is(nrQueuedBuildsForJobset($jobset), 3, "Evaluating jobs/basic.nix should result in 3 builds");
|
||||||
|
|
||||||
for my $build (queuedBuildsForJobset($jobset)) {
|
for my $build (queuedBuildsForJobset($jobset)) {
|
||||||
ok(runBuild($build), "Build '".$build->job."' from jobs/basic.nix should exit with code 0");
|
ok(runBuild($build), "Build '".$build->job."' from jobs/basic.nix should exit with return code 0");
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
is($newbuild->finished, 1, "Build '".$build->job."' from jobs/basic.nix should be finished.");
|
is($newbuild->finished, 1, "Build '".$build->job."' from jobs/basic.nix should be finished.");
|
||||||
my $expected = $build->job eq "fails" ? 1 : $build->job =~ /with_failed/ ? 6 : 0;
|
my $expected = $build->job eq "fails" ? 1 : $build->job =~ /with_failed/ ? 6 : 0;
|
||||||
|
|
|
@ -21,7 +21,7 @@ subtest "For the 'build1' job" => sub {
|
||||||
my ($build) = queuedBuildsForJobset($jobset);
|
my ($build) = queuedBuildsForJobset($jobset);
|
||||||
is($build->job, "build1", "Verify the only job we got is for 'build1'");
|
is($build->job, "build1", "Verify the only job we got is for 'build1'");
|
||||||
|
|
||||||
ok(runBuild($build), "Build should exit with code 0");
|
ok(runBuild($build), "Build should exit with return code 0");
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
is($newbuild->finished, 1, "Build should be finished.");
|
is($newbuild->finished, 1, "Build should be finished.");
|
||||||
is($newbuild->buildstatus, 0, "Build should have buildstatus 0.");
|
is($newbuild->buildstatus, 0, "Build should have buildstatus 0.");
|
||||||
|
@ -33,7 +33,7 @@ subtest "For the 'build2' job" => sub {
|
||||||
my ($build) = queuedBuildsForJobset($jobset);
|
my ($build) = queuedBuildsForJobset($jobset);
|
||||||
is($build->job, "build2", "Verify the only job we got is for 'build2'");
|
is($build->job, "build2", "Verify the only job we got is for 'build2'");
|
||||||
|
|
||||||
ok(runBuild($build), "Build should exit with code 0");
|
ok(runBuild($build), "Build should exit with return code 0");
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
is($newbuild->finished, 1, "Build should be finished.");
|
is($newbuild->finished, 1, "Build should be finished.");
|
||||||
is($newbuild->buildstatus, 0, "Build should have buildstatus 0.");
|
is($newbuild->buildstatus, 0, "Build should have buildstatus 0.");
|
||||||
|
|
|
@ -30,7 +30,7 @@ is(nrQueuedBuildsForJobset($jobset), 1, "Evaluating jobs/runcommand.nix should r
|
||||||
(my $build) = queuedBuildsForJobset($jobset);
|
(my $build) = queuedBuildsForJobset($jobset);
|
||||||
|
|
||||||
is($build->job, "metrics", "The only job should be metrics");
|
is($build->job, "metrics", "The only job should be metrics");
|
||||||
ok(runBuild($build), "Build should exit with code 0");
|
ok(runBuild($build), "Build should exit with return code 0");
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
is($newbuild->finished, 1, "Build should be finished.");
|
is($newbuild->finished, 1, "Build should be finished.");
|
||||||
is($newbuild->buildstatus, 0, "Build should have buildstatus 0.");
|
is($newbuild->buildstatus, 0, "Build should have buildstatus 0.");
|
||||||
|
|
|
@ -24,7 +24,7 @@ ok(evalSucceeds($jobset), "Evaluating jobs/default-machine-file.ni
|
||||||
is(nrQueuedBuildsForJobset($jobset), 1, "Evaluating jobs/default-machine-file.nix should result in 1 build");
|
is(nrQueuedBuildsForJobset($jobset), 1, "Evaluating jobs/default-machine-file.nix should result in 1 build");
|
||||||
|
|
||||||
for my $build (queuedBuildsForJobset($jobset)) {
|
for my $build (queuedBuildsForJobset($jobset)) {
|
||||||
ok(runBuild($build), "Build '".$build->job."' from jobs/default-machine-file.nix should exit with code 0");
|
ok(runBuild($build), "Build '".$build->job."' from jobs/default-machine-file.nix should exit with return code 0");
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
is($newbuild->finished, 1, "Build '".$build->job."' from jobs/default-machine-file.nix should be finished.");
|
is($newbuild->finished, 1, "Build '".$build->job."' from jobs/default-machine-file.nix should be finished.");
|
||||||
my $expected = $build->job eq "fails" ? 1 : $build->job =~ /with_failed/ ? 6 : 0;
|
my $expected = $build->job eq "fails" ? 1 : $build->job =~ /with_failed/ ? 6 : 0;
|
||||||
|
|
|
@ -88,7 +88,7 @@ my @builds = queuedBuildsForJobset($jobset);
|
||||||
|
|
||||||
subtest "Build: substitutable, canbesubstituted" => sub {
|
subtest "Build: substitutable, canbesubstituted" => sub {
|
||||||
my ($build) = grep { $_->nixname eq "can-be-substituted" } @builds;
|
my ($build) = grep { $_->nixname eq "can-be-substituted" } @builds;
|
||||||
ok(runBuild($build), "Build should exit with code 0");
|
ok(runBuild($build), "Build should exit with return code 0");
|
||||||
|
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
is($newbuild->finished, 1, "Build should be finished.");
|
is($newbuild->finished, 1, "Build should be finished.");
|
||||||
|
@ -107,7 +107,7 @@ subtest "Build: substitutable, canbesubstituted" => sub {
|
||||||
|
|
||||||
subtest "Build: not substitutable, unsubstitutable" => sub {
|
subtest "Build: not substitutable, unsubstitutable" => sub {
|
||||||
my ($build) = grep { $_->nixname eq "unsubstitutable" } @builds;
|
my ($build) = grep { $_->nixname eq "unsubstitutable" } @builds;
|
||||||
ok(runBuild($build), "Build should exit with code 0");
|
ok(runBuild($build), "Build should exit with return code 0");
|
||||||
|
|
||||||
my $newbuild = $db->resultset('Builds')->find($build->id);
|
my $newbuild = $db->resultset('Builds')->find($build->id);
|
||||||
is($newbuild->finished, 1, "Build should be finished.");
|
is($newbuild->finished, 1, "Build should be finished.");
|
||||||
|
|
Loading…
Reference in a new issue