3 <% if @object.state == 'Paused' %>
5 This pipeline is paused. Jobs that are
6 already running will continue to run, but no new jobs will be submitted.
11 <% if @object.started_at %>
12 Started at <span data-utc-date="<%= @object.started_at %>"><%= @object.started_at %></span>.
15 <% if @object.state == 'Complete' %>
17 <% elsif @object.state == 'Failed' %>
23 <% walltime = if @object.started_at
24 if @object.finished_at
25 @object.finished_at - @object.started_at
27 Time.now - @object.started_at
34 <%= runtime(walltime, true) %><% if @object.finished_at %> at <span data-utc-date="<%= @object.finished_at %>"><%= @object.finished_at %></span><% end %>.
36 <% if @object.state == 'Failed' %>
37 Check the Log tab for more detail about why this pipeline failed.
42 <% tasks = JobTask.filter([['job_uuid', 'in', render_pipeline_jobs.map { |j| j[:job].andand[:uuid] }]]).results %>
43 <% runningtime = determine_wallclock_runtime(render_pipeline_jobs.map {|j| j[:job]}) %>
45 <% if @object.state.start_with? 'Running' %>
51 <%= runtime(runningtime, true) %> (<%= runtime(walltime - runningtime, true) %> queued)<% if tasks.size == 0 %>.<% else %>
53 <% cputime = tasks.map { |task|
54 puts "started at #{task.started_at}"
56 (if task.finished_at then task.finished_at else Time.now() end) - task.started_at
61 <%= runtime(cputime, true) %>
62 of CPU time (<%= (cputime/runningtime).round(1) %>⨯ scaling).
68 <% render_pipeline_jobs.each_index do |i| %>
69 <% pj = render_pipeline_jobs[i] %>
70 <% current_job = pj[:job] if pj[:job] != {} %>
71 <div class="panel panel-default">
72 <div class="panel-heading">
73 <div class="container-fluid">
75 <div class="col-md-3">
76 <h4 class="panel-title">
77 <a data-toggle="collapse" href="#collapse<%= i %>">
78 <%= pj[:name] %> <span class="caret"></span>
83 <% puts current_job.inspect %>
86 <div class="col-md-1">
87 <%= render(partial: 'job_status_label', locals: { j: current_job }) %>
90 <div class="col-md-3">
91 <% if current_job[:started_at] %>
92 <% walltime = ((if current_job.finished_at then current_job.finished_at else Time.now() end) - current_job.started_at) %>
93 <% cputime = tasks.map { |task|
94 if task.started_at and task.job_uuid == current_job.uuid
95 (if task.finished_at then task.finished_at else Time.now() end) - task.started_at
100 <%= runtime(walltime, false) %> / <%= runtime(cputime, false) %> (<%= (cputime/walltime).round(1) %>⨯)
104 <% if Job::state(current_job).in? ["Completed", "Failed", "Canceled"] %>
105 <div class="col-md-3">
106 <% if pj[:output_uuid] %>
107 <%= link_to_if_arvados_object pj[:output_uuid] %>
108 <% elsif current_job.andand[:output] %>
109 <%= link_to_if_arvados_object current_job[:output], link_text: "Output of #{pj[:name]}" %>
114 <% elsif Job::state(current_job) == "Running" %>
115 <div class="col-md-3 pipeline-instance-spacing">
116 <%= pj[:progress_bar] %>
118 <div class="col-md-1 pipeline-instance-spacing">
119 <%= form_tag "/jobs/#{current_job.uuid}/cancel", style: "display:inline; padding-left: 1em" do |f| %>
120 <%= hidden_field_tag :return_to, url_for(@object) %>
121 <%= button_tag "Cancel", {class: 'btn btn-xs btn-danger', id: "cancel-job-button"} %>
124 <% elsif Job::state(current_job) == "Queued" %>
125 <div class="col-md-5">
126 <% queuetime = Time.now - current_job[:created_at] %>
127 Queued for <%= runtime(queuetime, true) %>.
129 <% if current_job.queue_position == 0 %>
130 This job is next in the queue to run.
131 <% elsif current_job.queue_position == 1 %>
132 There is 1 job in the queue ahead of this one.
134 There are <%= current_job.queue_position %> jobs in the queue ahead of this one.
141 <div class="col-md-3 col-md-offset-3">
142 <span class="label label-default">Not ready</span>
149 <div id="collapse<%= i %>" class="panel-collapse collapse">
150 <div class="panel-body">
151 <div class="container">
152 <% current_component = (if current_job then current_job else pj end) %>
154 <div class="col-md-6">
156 <% [:script, :repository, :script_version, :supplied_script_version, :nondeterministic].each do |k| %>
158 <td style="padding-right: 1em">
162 <%= current_component[k] %>
166 <% if current_component[:runtime_constraints].andand[:docker_image] and current_component[:docker_image_locator] %>
168 <td style="padding-right: 1em">
172 <%= current_component[:runtime_constraints][:docker_image] %>
176 <td style="padding-right: 1em">
177 docker_image_locator:
180 <%= link_to_if_arvados_object current_component[:docker_image_locator] %>
185 <td style="padding-right: 1em">
195 <div class="col-md-5">
197 <% [:uuid, :modified_by_user_uuid, :priority, :created_at, :started_at, :finished_at].each do |k| %>
199 <td style="padding-right: 1em">
203 <% if k.to_s.end_with? 'uuid' %>
204 <%= link_to_if_arvados_object current_component[k], friendly_name: true %>
205 <% elsif k.to_s.end_with? '_at' %>
206 <span data-utc-date="<%= current_component[k] %>"><%= current_component[k] %></span>
208 <%= current_component[k] %>
217 <div class="col-md-6">
218 <p>script_parameters:</p>
219 <pre><%= JSON.pretty_generate(current_component[:script_parameters]) rescue nil %></pre>
221 <% if current_component[:tasks_summary] %>
222 <div class="col-md-3">
224 <% [:done, :running, :failed, :todo].each do |d| %>
226 <td style="padding-right: 1em"><%= 'tasks:' if d == :done %></td>
227 <td style="padding-right: 1em"><%= d.to_s %></td>
228 <td><%= current_component[:tasks_summary][d] %></td>