[% USE date; USE String; USE HTML; inputTypes = { "svn" = "Subversion export" , "svn-checkout" = "Subversion checkout" , "bzr" = "Bazaar export" , "bzr-checkout" = "Bazaar checkout" , "git" = "Git checkout" , "hg" = "Mercurial checkout" , "string" = "String value" , "boolean" = "Boolean" , "path" = "Local path" , "build" = "Build output" , "sysbuild" = "Build output (same system)" }; BLOCK renderDateTime; date.format(timestamp, '%Y-%m-%d %H:%M:%S'); END; BLOCK renderProjectName %] [% project %] [% END; BLOCK renderJobsetName %] [% jobset %] [% END; BLOCK renderJobName %] [% job %] [% END; BLOCK renderFullJobsetName %] [% INCLUDE renderProjectName %]:[% INCLUDE renderJobsetName %] [% END; BLOCK renderFullJobName %] [% IF !hideProjectName; INCLUDE renderProjectName %]:[% END; IF !hideJobsetName; INCLUDE renderJobsetName %]:[% END; INCLUDE renderJobName %] [% END; BLOCK renderFullJobNameOfBuild; INCLUDE renderFullJobName project=build.get_column("project") jobset = build.get_column("jobset") job = build.get_column("job"); END; BLOCK renderDuration; IF duration >= 24 * 60 * 60; duration div (24 * 60 * 60) %]d [% END; IF duration >= 60 * 60; duration div (60 * 60) % 24 %]h [% END; IF duration >= 60; duration div 60 % 60 %]m [% END; duration % 60 %]s[% END; BLOCK renderBuildListHeader %] [% IF !hideResultInfo %] [% END %] [% IF showSchedulingInfo %] [% END %] [% IF showSchedulingInfo %] [% END %] [% IF !hideJobName %] [% END %] [% IF showStatusChange %] [% END %] [% IF showDescription %] [% END %] [% END; BLOCK renderBuildListBody; odd = 0; FOREACH build IN builds; %] [% IF !hideResultInfo %] [% END %] [% IF showSchedulingInfo %] [% END %] [% IF showSchedulingInfo %] [% END %] [% IF !hideJobName %] [% END %] [% IF showStatusChange %] [% END %] [% IF showDescription %] [% END %] [% END; END; BLOCK renderBuildListFooter %]
#PJobRelease Name System TimestampLast status changeDescription
[% INCLUDE renderBuildStatusIcon size=16 busy=(showSchedulingInfo ? 1 : 0) buildstatus=build.buildstatus %] [% IF build.busy %]Started[% ELSE %]Queued[% END %][% build.id %][% build.priority %][% INCLUDE renderFullJobNameOfBuild %][% !showSchedulingInfo and build.get_column('releasename') ? build.get_column('releasename') : build.nixname %] [% build.system %] [% date.format(build.timestamp, '%Y-%m-%d %H:%M:%S') %] [% IF build.get_column('statusChangeTime') %] [% date.format(build.get_column('statusChangeTime'), '%Y-%m-%d %H:%M:%S') %] [% ELSE %] never [% END %] [% build.description %]
[% END; BLOCK renderBuildList; INCLUDE renderBuildListHeader; INCLUDE renderBuildListBody; INCLUDE renderBuildListFooter; END; BLOCK renderLink %][% title %][% END; BLOCK showBuildStats %]
Finished builds: [% finishedBuilds %]
Succeeded Succeeded builds: [% succeededBuilds %]
Failed Failed builds: [% finishedBuilds - succeededBuilds %]
Total build time: [% INCLUDE renderDuration duration = totalBuildTime %]
Scheduled builds: [% scheduledBuilds %]
Currently executing builds: [% busyBuilds %]
[% END; BLOCK renderViewJobName; IF job.description; HTML.escape(job.description); ELSE %][% job.job %] ([% job.attrs %])[% END; END; BLOCK maybeLink; IF uri %] uri, class => class) %][% IF confirmmsg %]onclick="javascript:return confirm('[% confirmmsg %]')"[% END %]>[% content %][% ELSE; content; END; END; BLOCK renderSelection; IF edit; IF radiobuttons; %]
[% FOREACH name IN options.keys.sort %] [% END %]
[% ELSE %] [% END; ELSE; options.$curValue; END; END; BLOCK editString; %] param, name => param, value => value) %] /> END; BLOCK renderFullBuildLink; INCLUDE renderFullJobNameOfBuild build=build %] build [% build.id %][% END; BLOCK renderBuildStatusIcon; finished = build != undef ? build.finished : 1; busy = busy != undef ? busy : build.busy; buildstatus = buildstatus != undef ? buildstatus : build.buildstatus; IF finished; IF buildstatus == 0 %] Succeeded [% ELSIF buildstatus == 1 %] Failed [% ELSIF buildstatus == 2 %] Dependency failed [% ELSIF buildstatus == 4 %] Cancelled [% ELSIF buildstatus == 5 %] Failed [% ELSIF buildstatus == 6 %] Failed (with result) [% ELSE %] Failed [% END; ELSIF busy %] Busy [% ELSE %] Scheduled [% END; END; BLOCK renderStatus; IF build.finished; buildstatus = build.buildstatus; IF icon; INCLUDE renderBuildStatusIcon size=16; END; IF buildstatus == 0 %] Success [% ELSIF buildstatus == 1 %] Build returned a non-zero exit code [% ELSIF buildstatus == 2 %] A dependency of the build failed [% ELSIF buildstatus == 4 %] Cancelled by user [% ELSIF buildstatus == 5 %] Build inhibited because a dependency previously failed to build [% ELSIF buildstatus == 6 %] Build failed (with result) [% ELSE %] Build failed (see below) [% END; ELSIF build.busy %] Build in progress since [% INCLUDE renderDateTime timestamp = build.starttime; ELSE %] Scheduled to be built [% END; END; BLOCK renderInputValue; IF input.type == "build" || input.type == "sysbuild"; INCLUDE renderFullBuildLink build=input.dependency; ELSIF input.type == "string" || input.type == "boolean" %] "[% input.value %]" [% ELSE %] [% input.uri %][% IF input.revision %] (r[% input.revision %])[% END %] [% END; END; BLOCK renderShortInputValue; IF input.type == "build" || input.type == "sysbuild" %] [% input.dependency.id %] [% ELSIF input.type == "string" || input.type == "boolean" %] "[% input.value %]" [% ELSE %] [% input.uri %][% IF input.revision %] (r[% input.revision %])[% END %] [% END %] [% END; BLOCK renderDiffUri; nouri = 1; FOREACH m IN mappers; base = m.baseuri; url = bi1.uri; path = url.replace(base, ''); IF url.match(base) %] [% contents %] [% nouri = 0; END; END; IF nouri; res = bi1.uri.split(' '); url = res.0; branch = res.1; IF bi1.type == "hg" || bi1.type == "git" %] [% contents %] [% ELSE; contents; END; END; END; BLOCK renderInputDiff; %] [% IF !nestedDiff %] [% END; IF !nestLevel; nestLevel = 0; END; IF nestLevel <= 3; FOREACH bi1 IN build1.inputs; deletedInput = 1; FOREACH bi2 IN build2.inputs; IF bi1.name == bi2.name; IF bi1.type == bi2.type; IF bi1.value != bi2.value || bi1.uri != bi2.uri %] [% ELSIF bi1.uri == bi2.uri && bi1.revision != bi2.revision %] [% IF bi1.type == "git" %] [% ELSE %] [% END %] [% ELSIF bi1.dependency.id != bi2.dependency.id || bi1.path != bi2.path %] [% END %] [% ELSE %] [% END; deletedInput = 0; END; END; IF deletedInput == 1 %] [% END; END; END %]
InputChanges
[% bi1.name %][% INCLUDE renderShortInputValue input=bi1 %] to [% INCLUDE renderShortInputValue input=bi2 %]
[% bi1.name %][% INCLUDE renderDiffUri contents=(bi1.revision.substr(0, 6) _ ' to ' _ bi2.revision.substr(0, 6)) %]
[% bi1.name %][% INCLUDE renderDiffUri contents=(bi1.revision _ ' to ' _ bi2.revision) %]
[% bi1.name %][% INCLUDE renderShortInputValue input=bi1 %] to [% INCLUDE renderShortInputValue input=bi2 %]

[% INCLUDE renderInputDiff build1=bi1.dependency, build2=bi2.dependency, nestedDiff=1, nestLevel=nestLevel+1 %]
[% bi1.name %]Changed input type from '[% type = bi1.type; inputTypes.$type %]' to '[% type = bi2.type; inputTypes.$type %]'
[% bi1.name %]Input not present in this build.
[% END; BLOCK renderPager %] [% END; BLOCK renderShortEvalInput; IF input.type == "svn" || input.type == "svn-checkout" || input.type == "bzr" || input.type == "bzr-checkout" %] r[% input.revision %] [% ELSIF input.type == "git" %] [% input.revision.substr(0, 7) %] [% ELSIF input.type == "build" || input.type == "sysbuild" %] [% input.dependency.id %] [% ELSE %] [% input.revision %] [% END; END; BLOCK renderEvals %] [% FOREACH e IN evals; eval = e.eval; link = c.uri_for(c.controller('JobsetEval').action_for('view'), [eval.id]) %] [% END; IF linkToAll %] [% END %]
# Date Input changes Success
[% eval.id %] [% INCLUDE renderDateTime timestamp = eval.timestamp %] [% IF e.changedInputs.size > 0; sep=''; FOREACH input IN e.changedInputs; sep; %] [% input.name %] → [% INCLUDE renderShortEvalInput input=input; sep=','; END; ELSE %] - [% END %] [% e.nrSucceeded %] [% e.nrFailed %] [% IF e.nrScheduled > 0 %] [% e.nrScheduled %] [% END %] [% IF e.diff > 0 %] +[% e.diff %] [% ELSIF e.diff < 0 && e.nrScheduled == 0 %] [% e.diff %] [% END %]
More...
[% END; BLOCK renderLogLinks %] (log, raw, tail) [% END %]