1
0
mirror of https://github.com/ohwgiles/laminar.git synced 2024-10-27 20:34:20 +00:00

report running state, only show spinner when actually running

This commit is contained in:
Oliver Giles 2015-12-06 12:15:05 +01:00
parent 87ebf91f1e
commit f181c87d3b
5 changed files with 12 additions and 5 deletions

View File

@ -156,6 +156,7 @@ void Laminar::sendStatus(LaminarClient* client) {
j.set("queued", run->startedAt - run->queuedAt); j.set("queued", run->startedAt - run->queuedAt);
j.set("started", run->startedAt); j.set("started", run->startedAt);
j.set("reason", run->reason()); j.set("reason", run->reason());
j.set("result", to_string(RunState::RUNNING));
db->stmt("SELECT completedAt - startedAt FROM builds WHERE name = ? ORDER BY completedAt DESC LIMIT 1") db->stmt("SELECT completedAt - startedAt FROM builds WHERE name = ? ORDER BY completedAt DESC LIMIT 1")
.bind(run->name) .bind(run->name)
.fetch<int>([&](int etc){ .fetch<int>([&](int etc){
@ -188,6 +189,7 @@ void Laminar::sendStatus(LaminarClient* client) {
j.set("number", run->build); j.set("number", run->build);
j.set("node", run->node->name); j.set("node", run->node->name);
j.set("started", run->startedAt); j.set("started", run->startedAt);
j.set("result", to_string(RunState::RUNNING));
j.set("reason", run->reason()); j.set("reason", run->reason());
j.EndObject(); j.EndObject();
} }

View File

@ -306,7 +306,10 @@ angular.module('laminar',['ngRoute','ngSanitize'])
.run(function($rootScope) { .run(function($rootScope) {
angular.extend($rootScope, { angular.extend($rootScope, {
runIcon: function(result) { runIcon: function(result) {
return result === "success" ? '<span style="color:forestgreen;font-family:\'Zapf Dingbats\';">✔</span>' : result === "failed" ? '<span style="color:crimson;">✘</span>' : ''; return result === "success" ? '<span style="color:forestgreen;font-family:\'Zapf Dingbats\';">✔</span>' : result === "failed" || result === "aborted" ? '<span style="color:crimson;">✘</span>' : '';
},
runComplete: function(run) {
return !!run && (run.result === 'aborted' || run.result === 'failed' || run.result === 'success');
}, },
formatDate: function(unix) { formatDate: function(unix) {
// TODO reimplement when toLocaleDateString() accepts formatting // TODO reimplement when toLocaleDateString() accepts formatting

View File

@ -1,7 +1,7 @@
<div class="container-fluid"> <div class="container-fluid">
<div class="row"> <div class="row">
<div class="col-sm-5 col-md-6 col-lg-7"> <div class="col-sm-5 col-md-6 col-lg-7">
<h3 style="float:left"><img class="spin" src="/progress.png" ng-hide="job.result"><span ng-bind-html="runIcon(job.result)"></span> {{name}} #{{num}}</h3> <h3 style="float:left"><img class="spin" src="/progress.png" ng-show="job.result === 'running'"><span ng-bind-html="runIcon(job.result)"></span> {{name}} #{{num}}</h3>
<nav class="pull-left"> <nav class="pull-left">
<ul class="pagination" style="margin:15px 20px"> <ul class="pagination" style="margin:15px 20px">
<li ng-show="num > 1"><a href="jobs/{{name}}/{{num-1}}">&laquo;</a></li> <li ng-show="num > 1"><a href="jobs/{{name}}/{{num-1}}">&laquo;</a></li>
@ -13,12 +13,12 @@
<dt>Reason</dt><dd>{{job.reason}}</dd> <dt>Reason</dt><dd>{{job.reason}}</dd>
<dt>Queued for</dt><dd>{{job.queued}}s</dd> <dt>Queued for</dt><dd>{{job.queued}}s</dd>
<dt>Started</dt><dd>{{formatDate(job.started)}}</dd> <dt>Started</dt><dd>{{formatDate(job.started)}}</dd>
<dt ng-show="job.result">Completed</dt><dd ng-show="job.result">{{formatDate(job.completed)}}</dd> <dt ng-show="runComplete(job)">Completed</dt><dd ng-show="runComplete(job)">{{formatDate(job.completed)}}</dd>
<dt ng-show="job.result">Duration</dt><dd ng-show="job.result">{{job.duration}}s</dd> <dt ng-show="runComplete(job)">Duration</dt><dd ng-show="runComplete(job)">{{job.duration}}s</dd>
</dl> </dl>
</div> </div>
<div class="col-sm-7 col-md-6 col-lg-5"> <div class="col-sm-7 col-md-6 col-lg-5">
<div class="progress" ng-hide="job.result"> <div class="progress" ng-show="job.result == 'running'">
<div class="progress-bar progress-bar-{{job.overtime?'warning':'info'}} progress-bar-striped {{job.etc?'':'active'}}" style="width:{{!job.etc?'100':job.progress}}%;"></div> <div class="progress-bar progress-bar-{{job.overtime?'warning':'info'}} progress-bar-striped {{job.etc?'':'active'}}" style="width:{{!job.etc?'100':job.progress}}%;"></div>
</div> </div>
<div class="panel panel-default" ng-show="job.artifacts.length"> <div class="panel panel-default" ng-show="job.artifacts.length">

View File

@ -30,6 +30,7 @@ namespace fs = boost::filesystem;
std::string to_string(const RunState& rs) { std::string to_string(const RunState& rs) {
switch(rs) { switch(rs) {
case RunState::PENDING: return "pending"; case RunState::PENDING: return "pending";
case RunState::RUNNING: return "running";
case RunState::ABORTED: return "aborted"; case RunState::ABORTED: return "aborted";
case RunState::FAILED: return "failed"; case RunState::FAILED: return "failed";
case RunState::SUCCESS: return "success"; case RunState::SUCCESS: return "success";

View File

@ -29,6 +29,7 @@
enum class RunState { enum class RunState {
UNKNOWN, UNKNOWN,
PENDING, PENDING,
RUNNING,
ABORTED, ABORTED,
FAILED, FAILED,
SUCCESS SUCCESS