forked from lix-project/hydra
Remove the Errors page
The same info is readily available under the most recent jobset eval page.
This commit is contained in:
parent
64d617a6b2
commit
c7a039bd05
7 changed files with 13 additions and 139 deletions
|
@ -7,38 +7,6 @@ use Hydra::Helper::Nix;
|
||||||
use Hydra::Helper::CatalystUtils;
|
use Hydra::Helper::CatalystUtils;
|
||||||
|
|
||||||
|
|
||||||
sub getJobStatus {
|
|
||||||
my ($self, $c) = @_;
|
|
||||||
|
|
||||||
my $maintainer = $c->request->params->{"maintainer"};
|
|
||||||
|
|
||||||
my $latest = $c->stash->{jobStatus}->search(
|
|
||||||
defined $maintainer ? { maintainers => { like => "%$maintainer%" } } : {},
|
|
||||||
{ '+select' => ["me.statusChangeId", "me.statusChangeTime"]
|
|
||||||
, '+as' => ["statusChangeId", "statusChangeTime"]
|
|
||||||
, order_by => "coalesce(statusChangeTime, 0) desc"
|
|
||||||
});
|
|
||||||
|
|
||||||
return $latest;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
# A convenient way to see all the errors - i.e. things demanding
|
|
||||||
# attention - at a glance.
|
|
||||||
sub errors : Chained('get_builds') PathPart Args(0) {
|
|
||||||
my ($self, $c) = @_;
|
|
||||||
$c->stash->{template} = 'errors.tt';
|
|
||||||
$c->stash->{brokenJobsets} =
|
|
||||||
[$c->stash->{allJobsets}->search({errormsg => {'!=' => ''}})]
|
|
||||||
if defined $c->stash->{allJobsets};
|
|
||||||
$c->stash->{brokenJobs} =
|
|
||||||
[$c->stash->{allJobs}->search({errormsg => {'!=' => ''}})]
|
|
||||||
if defined $c->stash->{allJobs};
|
|
||||||
$c->stash->{brokenBuilds} =
|
|
||||||
[getJobStatus($self, $c)->search({buildStatus => {'!=' => 0}})];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
sub all : Chained('get_builds') PathPart {
|
sub all : Chained('get_builds') PathPart {
|
||||||
my ($self, $c) = @_;
|
my ($self, $c) = @_;
|
||||||
|
|
||||||
|
|
|
@ -40,26 +40,26 @@ sub overview : Chained('job') PathPart('') Args(0) {
|
||||||
|
|
||||||
# If this is an aggregate job, then get its constituents.
|
# If this is an aggregate job, then get its constituents.
|
||||||
my @constituents = $c->model('DB::Builds')->search(
|
my @constituents = $c->model('DB::Builds')->search(
|
||||||
{ aggregate => { -in => $job->builds->search({}, { columns => ["id"], order_by => "id desc", rows => 15 })->as_query } },
|
{ aggregate => { -in => $job->builds->search({}, { columns => ["id"], order_by => "id desc", rows => 15 })->as_query } },
|
||||||
{ join => 'aggregateconstituents_constituents',
|
{ join => 'aggregateconstituents_constituents',
|
||||||
columns => ['id', 'job', 'finished', 'buildstatus'],
|
columns => ['id', 'job', 'finished', 'buildstatus'],
|
||||||
+select => ['aggregateconstituents_constituents.aggregate'],
|
+select => ['aggregateconstituents_constituents.aggregate'],
|
||||||
+as => ['aggregate']
|
+as => ['aggregate']
|
||||||
});
|
});
|
||||||
|
|
||||||
my $aggregates = {};
|
my $aggregates = {};
|
||||||
my %constituentJobs;
|
my %constituentJobs;
|
||||||
foreach my $b (@constituents) {
|
foreach my $b (@constituents) {
|
||||||
my $jobName = $b->get_column('job');
|
my $jobName = $b->get_column('job');
|
||||||
$aggregates->{$b->get_column('aggregate')}->{constituents}->{$jobName} =
|
$aggregates->{$b->get_column('aggregate')}->{constituents}->{$jobName} =
|
||||||
{ id => $b->id, finished => $b->finished, buildstatus => $b->buildstatus };
|
{ id => $b->id, finished => $b->finished, buildstatus => $b->buildstatus };
|
||||||
$constituentJobs{$jobName} = 1;
|
$constituentJobs{$jobName} = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach my $agg (keys %$aggregates) {
|
foreach my $agg (keys %$aggregates) {
|
||||||
# FIXME: could be done in one query.
|
# FIXME: could be done in one query.
|
||||||
$aggregates->{$agg}->{build} =
|
$aggregates->{$agg}->{build} =
|
||||||
$c->model('DB::Builds')->find({id => $agg}, {columns => [@buildListColumns]}) or die;
|
$c->model('DB::Builds')->find({id => $agg}, {columns => [@buildListColumns]}) or die;
|
||||||
}
|
}
|
||||||
|
|
||||||
$c->stash->{aggregates} = $aggregates;
|
$c->stash->{aggregates} = $aggregates;
|
||||||
|
@ -73,7 +73,6 @@ sub get_builds : Chained('job') PathPart('') CaptureArgs(0) {
|
||||||
$c->stash->{allBuilds} = $c->stash->{job}->builds;
|
$c->stash->{allBuilds} = $c->stash->{job}->builds;
|
||||||
$c->stash->{jobStatus} = $c->model('DB')->resultset('JobStatusForJob')
|
$c->stash->{jobStatus} = $c->model('DB')->resultset('JobStatusForJob')
|
||||||
->search({}, {bind => [$c->stash->{project}->name, $c->stash->{jobset}->name, $c->stash->{job}->name]});
|
->search({}, {bind => [$c->stash->{project}->name, $c->stash->{jobset}->name, $c->stash->{job}->name]});
|
||||||
$c->stash->{allJobs} = $c->stash->{job_};
|
|
||||||
$c->stash->{latestSucceeded} = $c->model('DB')->resultset('LatestSucceededForJob')
|
$c->stash->{latestSucceeded} = $c->model('DB')->resultset('LatestSucceededForJob')
|
||||||
->search({}, {bind => [$c->stash->{project}->name, $c->stash->{jobset}->name, $c->stash->{job}->name]});
|
->search({}, {bind => [$c->stash->{project}->name, $c->stash->{jobset}->name, $c->stash->{job}->name]});
|
||||||
$c->stash->{channelBaseName} =
|
$c->stash->{channelBaseName} =
|
||||||
|
|
|
@ -185,8 +185,6 @@ sub get_builds : Chained('jobsetChain') PathPart('') CaptureArgs(0) {
|
||||||
$c->stash->{allBuilds} = $c->stash->{jobset}->builds;
|
$c->stash->{allBuilds} = $c->stash->{jobset}->builds;
|
||||||
$c->stash->{jobStatus} = $c->model('DB')->resultset('JobStatusForJobset')
|
$c->stash->{jobStatus} = $c->model('DB')->resultset('JobStatusForJobset')
|
||||||
->search({}, {bind => [$c->stash->{project}->name, $c->stash->{jobset}->name]});
|
->search({}, {bind => [$c->stash->{project}->name, $c->stash->{jobset}->name]});
|
||||||
$c->stash->{allJobsets} = $c->stash->{jobset_};
|
|
||||||
$c->stash->{allJobs} = $c->stash->{jobset}->jobs;
|
|
||||||
$c->stash->{latestSucceeded} = $c->model('DB')->resultset('LatestSucceededForJobset')
|
$c->stash->{latestSucceeded} = $c->model('DB')->resultset('LatestSucceededForJobset')
|
||||||
->search({}, {bind => [$c->stash->{project}->name, $c->stash->{jobset}->name]});
|
->search({}, {bind => [$c->stash->{project}->name, $c->stash->{jobset}->name]});
|
||||||
$c->stash->{channelBaseName} =
|
$c->stash->{channelBaseName} =
|
||||||
|
|
|
@ -204,8 +204,6 @@ sub get_builds : Chained('projectChain') PathPart('') CaptureArgs(0) {
|
||||||
$c->stash->{allBuilds} = $c->stash->{project}->builds;
|
$c->stash->{allBuilds} = $c->stash->{project}->builds;
|
||||||
$c->stash->{jobStatus} = $c->model('DB')->resultset('JobStatusForProject')
|
$c->stash->{jobStatus} = $c->model('DB')->resultset('JobStatusForProject')
|
||||||
->search({}, {bind => [$c->stash->{project}->name]});
|
->search({}, {bind => [$c->stash->{project}->name]});
|
||||||
$c->stash->{allJobsets} = $c->stash->{project}->jobsets;
|
|
||||||
$c->stash->{allJobs} = $c->stash->{project}->jobs;
|
|
||||||
$c->stash->{latestSucceeded} = $c->model('DB')->resultset('LatestSucceededForProject')
|
$c->stash->{latestSucceeded} = $c->model('DB')->resultset('LatestSucceededForProject')
|
||||||
->search({}, {bind => [$c->stash->{project}->name]});
|
->search({}, {bind => [$c->stash->{project}->name]});
|
||||||
$c->stash->{channelBaseName} = $c->stash->{project}->name;
|
$c->stash->{channelBaseName} = $c->stash->{project}->name;
|
||||||
|
|
|
@ -151,8 +151,6 @@ sub get_builds : Chained('/') PathPart('') CaptureArgs(0) {
|
||||||
my ($self, $c) = @_;
|
my ($self, $c) = @_;
|
||||||
$c->stash->{allBuilds} = $c->model('DB::Builds');
|
$c->stash->{allBuilds} = $c->model('DB::Builds');
|
||||||
$c->stash->{jobStatus} = $c->model('DB')->resultset('JobStatus');
|
$c->stash->{jobStatus} = $c->model('DB')->resultset('JobStatus');
|
||||||
$c->stash->{allJobsets} = $c->model('DB::Jobsets');
|
|
||||||
$c->stash->{allJobs} = $c->model('DB::Jobs');
|
|
||||||
$c->stash->{latestSucceeded} = $c->model('DB')->resultset('LatestSucceeded');
|
$c->stash->{latestSucceeded} = $c->model('DB')->resultset('LatestSucceeded');
|
||||||
$c->stash->{channelBaseName} = "everything";
|
$c->stash->{channelBaseName} = "everything";
|
||||||
$c->stash->{total} = $c->model('DB::NrBuilds')->find('finished')->count;
|
$c->stash->{total} = $c->model('DB::NrBuilds')->find('finished')->count;
|
||||||
|
|
|
@ -1,80 +0,0 @@
|
||||||
[% WRAPPER layout.tt title="Errors" %]
|
|
||||||
[% PROCESS common.tt %]
|
|
||||||
|
|
||||||
<p>This page provides a quick way to see how FUBARed your packages
|
|
||||||
are. It shows job expressions that don’t evaluate properly and jobs
|
|
||||||
that don’t build.</p>
|
|
||||||
|
|
||||||
|
|
||||||
[% haveErrors = 0 %]
|
|
||||||
|
|
||||||
|
|
||||||
[% IF brokenJobsets && brokenJobsets.size > 0; haveErrors = 1 %]
|
|
||||||
|
|
||||||
<h2>Evaluation errors in jobsets</h2>
|
|
||||||
|
|
||||||
<table class="table table-condensed table-striped">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th>Name</th>
|
|
||||||
<th>Error</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tdata>
|
|
||||||
[% FOREACH j IN brokenJobsets %]
|
|
||||||
<tr>
|
|
||||||
<td>[% INCLUDE renderFullJobsetName project=j.project.name jobset=j.name %]</td>
|
|
||||||
<td>
|
|
||||||
<pre class="error">[% HTML.escape(j.errormsg) %]</pre>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
[% END %]
|
|
||||||
</tdata>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
[% END %]
|
|
||||||
|
|
||||||
|
|
||||||
[% IF brokenJobs && brokenJobs.size > 0; haveErrors = 1 %]
|
|
||||||
|
|
||||||
<h2>Evaluation errors in jobs</h2>
|
|
||||||
|
|
||||||
<table class="table table-condensed table-striped">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th>Name</th>
|
|
||||||
<th>Error</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tdata>
|
|
||||||
[% FOREACH j IN brokenJobs %]
|
|
||||||
<tr>
|
|
||||||
<td>[% INCLUDE renderFullJobName project=j.project.name jobset=j.jobset.name job=j.name %]</td>
|
|
||||||
<td>
|
|
||||||
<pre class="error">[% HTML.escape(j.errormsg) %]</pre>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
[% END %]
|
|
||||||
</tdata>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
[% END %]
|
|
||||||
|
|
||||||
|
|
||||||
[% IF brokenBuilds && brokenBuilds.size > 0; haveErrors = 1 %]
|
|
||||||
|
|
||||||
<h2>Broken builds</h2>
|
|
||||||
|
|
||||||
[% INCLUDE renderBuildList builds=brokenBuilds showStatusChange=1 hideProjectName=project hideJobsetName=jobset hideJobName=job %]
|
|
||||||
|
|
||||||
[% END %]
|
|
||||||
|
|
||||||
|
|
||||||
[% IF !haveErrors %]
|
|
||||||
|
|
||||||
<p><strong>There are currently no problems.</strong></p>
|
|
||||||
|
|
||||||
[% END %]
|
|
||||||
|
|
||||||
|
|
||||||
[% END %]
|
|
|
@ -33,7 +33,6 @@
|
||||||
<li class="divider"></li>
|
<li class="divider"></li>
|
||||||
[% INCLUDE menuItem uri = c.uri_for(c.controller('Project').action_for('project'), [project.name]) title = "Overview" %]
|
[% INCLUDE menuItem uri = c.uri_for(c.controller('Project').action_for('project'), [project.name]) title = "Overview" %]
|
||||||
[% INCLUDE menuItem uri = c.uri_for(c.controller('Project').action_for('all'), [project.name]) title = "Latest builds" %]
|
[% INCLUDE menuItem uri = c.uri_for(c.controller('Project').action_for('all'), [project.name]) title = "Latest builds" %]
|
||||||
[% INCLUDE menuItem uri = c.uri_for(c.controller('Project').action_for('errors'), [project.name]) title = "Errors" %]
|
|
||||||
[% INCLUDE menuItem uri = c.uri_for('/project' project.name 'channel' 'latest') title = "Channel" %]
|
[% INCLUDE menuItem uri = c.uri_for('/project' project.name 'channel' 'latest') title = "Channel" %]
|
||||||
[% END %]
|
[% END %]
|
||||||
[% END %]
|
[% END %]
|
||||||
|
@ -51,9 +50,6 @@
|
||||||
[% INCLUDE menuItem
|
[% INCLUDE menuItem
|
||||||
uri = c.uri_for(c.controller('Jobset').action_for('all'), [project.name, jobset.name])
|
uri = c.uri_for(c.controller('Jobset').action_for('all'), [project.name, jobset.name])
|
||||||
title = "Latest builds" %]
|
title = "Latest builds" %]
|
||||||
[% INCLUDE menuItem
|
|
||||||
uri = c.uri_for(c.controller('Jobset').action_for('errors'), [project.name, jobset.name])
|
|
||||||
title = "Errors" %]
|
|
||||||
[% INCLUDE menuItem uri = c.uri_for('/jobset' project.name jobset.name 'channel' 'latest') title = "Channel" %]
|
[% INCLUDE menuItem uri = c.uri_for('/jobset' project.name jobset.name 'channel' 'latest') title = "Channel" %]
|
||||||
[% END %]
|
[% END %]
|
||||||
[% END %]
|
[% END %]
|
||||||
|
@ -68,9 +64,6 @@
|
||||||
[% INCLUDE menuItem
|
[% INCLUDE menuItem
|
||||||
uri = c.uri_for(c.controller('Job').action_for('all'), [project.name, jobset.name, job.name])
|
uri = c.uri_for(c.controller('Job').action_for('all'), [project.name, jobset.name, job.name])
|
||||||
title = "Latest builds" %]
|
title = "Latest builds" %]
|
||||||
[% INCLUDE menuItem
|
|
||||||
uri = c.uri_for(c.controller('Job').action_for('errors'), [project.name, jobset.name, job.name])
|
|
||||||
title = "Errors" %]
|
|
||||||
[% INCLUDE menuItem uri = c.uri_for('/job' project.name jobset.name job.name 'channel' 'latest') title = "Channel" %]
|
[% INCLUDE menuItem uri = c.uri_for('/job' project.name jobset.name job.name 'channel' 'latest') title = "Channel" %]
|
||||||
[% END %]
|
[% END %]
|
||||||
[% END %]
|
[% END %]
|
||||||
|
|
Loading…
Reference in a new issue