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> and
17 <% if @object.state == 'Complete' %>
19 <% elsif @object.state == 'Failed' %>
21 <% elsif @object.started_at %>
25 <% walltime = if @object.started_at
26 if @object.finished_at
27 @object.finished_at - @object.started_at
29 Time.now - @object.started_at
36 <%= runtime(walltime, true) %><% if @object.finished_at %> at <span data-utc-date="<%= @object.finished_at %>"><%= @object.finished_at %></span><% end %>.
38 <% if @object.state == 'Failed' %>
39 Check the Log tab for more detail about why this pipeline failed.
44 <% tasks = JobTask.filter([['job_uuid', 'in', render_pipeline_jobs.map { |j| j[:job].andand[:uuid] }]]).results %>
45 <% runningtime = determine_wallclock_runtime(render_pipeline_jobs.map {|j| j[:job]}) %>
47 <% if @object.state.start_with? 'Running' %>
53 <%= runtime(runningtime, true) %> (<%= runtime(walltime - runningtime, true) %> queued)<% if tasks.size == 0 %>.<% else %>
55 <% cputime = tasks.map { |task|
56 puts "started at #{task.started_at}"
58 (if task.finished_at then task.finished_at else Time.now() end) - task.started_at
63 <%= runtime(cputime, true) %>
64 of CPU time (<%= (cputime/runningtime).round(1) %>⨯ scaling).
70 <% render_pipeline_jobs.each_index do |i| %>
71 <% pj = render_pipeline_jobs[i] %>
72 <% current_job = pj[:job] if pj[:job] != {} %>
73 <div class="panel panel-default">
74 <div class="panel-heading">
75 <div class="container-fluid">
77 <div class="col-md-3">
78 <h4 class="panel-title">
79 <a data-toggle="collapse" data-parent="#accordion" href="#collapse<%= i %>">
80 <%= pj[:name] %> <span class="caret"></span>
85 <% puts current_job.inspect %>
88 <div class="col-md-1">
89 <%= render(partial: 'job_status_label', locals: { j: current_job }) %>
92 <div class="col-md-3">
93 <% if current_job[:started_at] %>
94 <% walltime = ((if current_job.finished_at then current_job.finished_at else Time.now() end) - current_job.started_at) %>
95 <% cputime = tasks.map { |task|
96 if task.started_at and task.job_uuid == current_job.uuid
97 (if task.finished_at then task.finished_at else Time.now() end) - task.started_at
102 <%= runtime(walltime, false) %> / <%= runtime(cputime, false) %> (<%= (cputime/walltime).round(1) %>⨯)
106 <% if Job::state(current_job).in? ["Completed", "Failed", "Canceled"] %>
107 <div class="col-md-3">
108 <% if pj[:output_uuid] %>
109 <%= link_to_if_arvados_object pj[:output_uuid] %>
110 <% elsif current_job.andand[:output] %>
111 <%= link_to_if_arvados_object current_job[:output], link_text: "Output of #{pj[:name]}" %>
116 <% elsif Job::state(current_job) == "Running" %>
117 <div class="col-md-3 pipeline-instance-spacing">
118 <%= pj[:progress_bar] %>
120 <div class="col-md-1 pipeline-instance-spacing">
121 <%= form_tag "/jobs/#{current_job.uuid}/cancel", style: "display:inline; padding-left: 1em" do |f| %>
122 <%= hidden_field_tag :return_to, url_for(@object) %>
123 <%= button_tag "Cancel", {class: 'btn btn-xs btn-danger', id: "cancel-job-button"} %>
126 <% elsif Job::state(current_job) == "Queued" %>
127 <div class="col-md-5">
128 <% queuetime = Time.now - current_job[:created_at] %>
129 Queued for <%= runtime(queuetime, true) %>.
130 <% if current_job.queue_position == 0 %>
131 This job is next in the queue to run.
132 <% elsif current_job.queue_position == 1 %>
133 There is 1 job in the queue ahead of this one.
135 There are <%= current_job.queue_position %> jobs in the queue ahead of this one.
140 <div class="col-md-3 col-md-offset-3">
141 <span class="label label-default">Not ready</span>
148 <div id="collapse<%= i %>" class="panel-collapse collapse">
149 <div class="panel-body">
150 <div class="container">
151 <% current_component = (if current_job then current_job else pj end) %>
153 <div class="col-md-6">
155 <% [:script, :repository, :script_version, :supplied_script_version, :nondeterministic].each do |k| %>
157 <td style="padding-right: 1em">
161 <%= current_component[k] %>
165 <% if current_component[:runtime_constraints].andand[:docker_image] and current_component[:docker_image_locator] %>
167 <td style="padding-right: 1em">
171 <%= current_component[:runtime_constraints][:docker_image] %>
175 <td style="padding-right: 1em">
176 docker_image_locator:
179 <%= link_to_if_arvados_object current_component[:docker_image_locator] %>
184 <td style="padding-right: 1em">
194 <div class="col-md-5">
196 <% [:uuid, :modified_by_user_uuid, :priority, :created_at, :started_at, :finished_at].each do |k| %>
198 <td style="padding-right: 1em">
202 <% if k.to_s.end_with? 'uuid' %>
203 <%= link_to_if_arvados_object current_component[k], friendly_name: true %>
204 <% elsif k.to_s.end_with? '_at' %>
205 <span data-utc-date="<%= current_component[k] %>"><%= current_component[k] %></span>
207 <%= current_component[k] %>
216 <div class="col-md-6">
217 <p>script_parameters:</p>
218 <pre><%= JSON.pretty_generate(current_component[:script_parameters]) rescue nil %></pre>
220 <% if current_component[:tasks_summary] %>
221 <div class="col-md-3">
223 <% [:done, :running, :failed, :todo].each do |d| %>
225 <td style="padding-right: 1em"><%= 'tasks:' if d == :done %></td>
226 <td style="padding-right: 1em"><%= d.to_s %></td>
227 <td><%= current_component[:tasks_summary][d] %></td>