X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/f4ca9ad94a6bb006d1f3c7ba207837f1736d1247..cbd67fc6ba667bc27ca7e885145a6e34e5596f37:/apps/workbench/app/views/projects/_show_dashboard.html.erb diff --git a/apps/workbench/app/views/projects/_show_dashboard.html.erb b/apps/workbench/app/views/projects/_show_dashboard.html.erb index 47a2723547..8abcee49e6 100644 --- a/apps/workbench/app/views/projects/_show_dashboard.html.erb +++ b/apps/workbench/app/views/projects/_show_dashboard.html.erb @@ -1,129 +1,106 @@
-
Active pipelines +
+ Recent pipelines and processes <% if current_user.andand.is_active %> - - <%= link_to( - choose_pipeline_templates_path( - title: 'Choose a pipeline to run:', - action_name: 'Next: choose inputs ', - action_href: pipeline_instances_path, - action_method: 'post', - action_data: {'selection_param' => 'pipeline_instance[pipeline_template_uuid]', 'pipeline_instance[owner_uuid]' => current_user.uuid, 'success' => 'redirect-to-created-object'}.to_json), - { class: "btn btn-primary btn-xs", remote: true }) do %> - Run a pipeline... - <% end %> - - <% end %> -
- - <% _running_pipelines = running_pipelines %> - <% _finished_pipelines = finished_pipelines(8) %> - <% lookup = preload_objects_for_dataclass PipelineTemplate, (_running_pipelines.map(&:pipeline_template_uuid) + _finished_pipelines.map(&:pipeline_template_uuid)) %> - -
- <% if _running_pipelines.empty? %> - No pipelines are currently running. - <% else %> - <% _running_pipelines.each do |p| %> -
-
- <%= link_to_if_arvados_object p, {friendly_name: true, lookup: lookup} %> - -
-
- <% p.components.each do |k, v| %> - <% if v.is_a? Hash and v[:job] %> - <%= render partial: 'job_progress', locals: {:j => v[:job], :scaleby => (1.0/p.components.size)} %> - <% end %> - <% end %> -
-
-
- - <% - running = p.components.select { |k, c| c.is_a? Hash and c[:job].andand[:state] == "Running" } - queued = p.components.select { |k, c| c.is_a? Hash and c[:job].andand[:state] == "Queued" } - %> - -
- Started at <%= render_localized_date(p[:started_at] || p[:created_at], "noseconds") %>. - <% pipeline_time = Time.now - (p[:started_at] || p[:created_at]) %> - Active for <%= render_runtime(pipeline_time, false) %>. - -
- <% running.each do |k,v| %> - <%= render partial: 'job_progress', locals: {:j => v[:job], :show_progress_bar => false, :title => k} %> + + + <%= link_to( + choose_pipeline_templates_path( + title: 'Choose a pipeline to run:', + action_name: 'Next: choose inputs ', + action_href: pipeline_instances_path, + action_method: 'post', + action_data: {'selection_param' => 'pipeline_instance[pipeline_template_uuid]', 'pipeline_instance[owner_uuid]' => current_user.uuid, 'success' => 'redirect-to-created-object'}.to_json), + { class: "btn btn-primary btn-xs", remote: true }) do %> + Run a pipeline... + <% end %> + + + <%= link_to pipeline_instances_path, class: 'btn btn-default btn-xs' do %> + All pipelines <% end %> - <% queued.each do |k,v| %> - <%= render partial: 'job_progress', locals: {:j => v[:job], :show_progress_bar => false, :title => k} %> - <% end %> -
-
-
- <% end %> + + <% end %>
-
-
-
Recently finished pipelines - - <%= link_to pipeline_instances_path, class: 'btn btn-default btn-xs' do %> - All pipelines - <% end %> - -
-
- <% _finished_pipelines.each do |p| %> -
+ <% _recent_processes = recent_processes(12) %> +
+ <% if _recent_processes.empty? %> + No recent pipelines or processes. + <% else %> + <% _recent_processes.each do |p| %> + <% wu = p.work_unit %> + <% if wu.is_finished? %> +
- <%= link_to_if_arvados_object p, {friendly_name: true, lookup: lookup} %> + <%= link_to_if_arvados_object p, {friendly_name: true} %>
- <%= render partial: "pipeline_status_label", locals: {p: p}%> + <%=wu.state_label%>
- <%= render_localized_date(p[:finished_at] || p[:modified_at], "noseconds") %> + <%= render_localized_date(wu.finished_at || wu.modified_at, "noseconds") %>
- <% if p[:started_at] and p[:finished_at] %> - <% pipeline_time = p[:finished_at] - p[:started_at] %> - Active for <%= render_runtime(pipeline_time, false) %> + <% if wu.started_at and wu.finished_at %> + <% wu_time = wu.finished_at - wu.started_at %> + Active for <%= render_runtime(wu_time, false) %> <% end %> - <% outputs = [] %> - <% p.components.each do |k, c| %> - <% outputs << c[:output_uuid] if c[:output_uuid] %> - <% end %> + <% outputs = wu.outputs %> <% if outputs.size == 0 %> No output. <% elsif outputs.size == 1 %> <%= link_to_if_arvados_object outputs[0], friendly_name: true %> <% else %> - Outputs + <%= render partial: 'work_unit/show_outputs', locals: {id: wu.uuid, outputs: outputs, align:"pull-right"} %> <% end %>
-
-
-
- <% outputs.each do |out| %> -
- <%= link_to_if_arvados_object out, friendly_name: true %> -
- <% end %> +
+ <% else %> +
+
+ <%= link_to_if_arvados_object p, {friendly_name: true} %> +
+
+ <% wu.progress %>
+ + <% + children = wu.children + running = children.select { |c| c.state_label == "Running" } + queued = children.select { |c| c.state_label == "Queued" } + %> + +
+ Started at <%= render_localized_date(wu.started_at || wu.created_at, "noseconds") %>. + <% wu_time = Time.now - (wu.started_at || wu.created_at) %> + Active for <%= render_runtime(wu_time, false) %>. + +
+ <% running.each do |r| %> + <%= r.label || r.state_label || 'Not ready' %> + <% end %> + <% queued.each do |q| %> + <%= q.label || r.state_label || 'Not ready' %> + <% end %> +
+
+ <% end %> + <% end %> <% end %>
@@ -132,22 +109,39 @@
<% nodes = Node.all %>
-
Compute and job status - - <%= link_to jobs_path, class: 'btn btn-default btn-xs' do %> - All jobs +
Compute node status + + <% if current_user.andand.is_admin %> + + <%= link_to nodes_path, class: 'btn btn-default btn-xs' do %> + All nodes + <% end %> + <% end %> + + <%= link_to jobs_path, class: 'btn btn-default btn-xs' do %> + All jobs + <% end %> +
-
+
<%= render partial: 'compute_node_summary', locals: {nodes: nodes} %> - + <% active_nodes = [] %> + <% nodes.sort_by { |n| n.hostname || "" }.each do |n| %> + <% if n.crunch_worker_state.in? ["busy", "idle"] and (Time.now - n[:last_ping_at]) < 3600 %> + <% active_nodes << n %> + <% end %> + <% end %> + <% if active_nodes.any? %> + + <% end %>
- <%= render partial: 'compute_node_status', locals: {nodes: nodes} %> + <%= render partial: 'compute_node_status', locals: {nodes: active_nodes} %>