[ARVADOS] created: 23c8dd0d911c4b238169f399ff455f2dab9f0b4f
Git user
git at public.curoverse.com
Mon May 29 13:21:35 EDT 2017
at 23c8dd0d911c4b238169f399ff455f2dab9f0b4f (commit)
commit 23c8dd0d911c4b238169f399ff455f2dab9f0b4f
Author: radhika <radhika at curoverse.com>
Date: Mon May 29 13:19:05 2017 -0400
11739: preload containers and children of all container_requests in dashboard display.
11751: in /container_requests page, use the column name "Name" and display either name of uuid of the object.
diff --git a/apps/workbench/app/views/container_requests/_show_recent.html.erb b/apps/workbench/app/views/container_requests/_show_recent.html.erb
index 6a4c8b1..7ee20db 100644
--- a/apps/workbench/app/views/container_requests/_show_recent.html.erb
+++ b/apps/workbench/app/views/container_requests/_show_recent.html.erb
@@ -3,8 +3,8 @@
<table class="table table-condensed table-fixedlayout arv-recent-container-requests">
<colgroup>
<col width="10%" />
- <col width="15%" />
- <col width="25%" />
+ <col width="20%" />
+ <col width="20%" />
<col width="15%" />
<col width="15%" />
<col width="15%" />
@@ -15,7 +15,7 @@
<th>
Status
</th><th>
- Container request
+ Name
</th><th>
Description
</th><th>
diff --git a/apps/workbench/app/views/container_requests/_show_recent_rows.html.erb b/apps/workbench/app/views/container_requests/_show_recent_rows.html.erb
index d11bf35..6caf6d5 100644
--- a/apps/workbench/app/views/container_requests/_show_recent_rows.html.erb
+++ b/apps/workbench/app/views/container_requests/_show_recent_rows.html.erb
@@ -20,7 +20,7 @@
<td>
<span class="label label-<%= wu.state_bootstrap_class %>"><%= wu.state_label %></span>
</td><td>
- <%= link_to_if_arvados_object obj, friendly_name: true %>
+ <%= link_to_if_arvados_object obj, friendly_name: true, link_text: if !obj.name.empty? then obj.name else obj.uuid end %>
</td><td>
<%= obj.description || '' %>
</td><td>
diff --git a/apps/workbench/app/views/projects/_show_dashboard.html.erb b/apps/workbench/app/views/projects/_show_dashboard.html.erb
index bcfeb6a..f472b1e 100644
--- a/apps/workbench/app/views/projects/_show_dashboard.html.erb
+++ b/apps/workbench/app/views/projects/_show_dashboard.html.erb
@@ -1,10 +1,32 @@
<%
recent_procs = recent_processes(12)
+ # preload container_uuids of any container requests
+ recent_crs = recent_procs.map {|p| p if p.is_a?(ContainerRequest)}.compact.uniq
+ recent_cr_containers = recent_crs.map {|cr| cr.container_uuid}.compact.uniq
+ preload_objects_for_dataclass(Container, recent_cr_containers) if recent_cr_containers.andand.any?
+
+ # fetch children of all the active crs in one call, if there are any
+ active_crs = recent_crs.each {|cr| cr if (cr.priority > 0 and cr.state != 'Final' and cr.container_uuid)}
+ active_cr_uuids = active_crs.map(&:uuid)
+ active_cr_containers = active_crs.map {|cr| cr.container_uuid}.compact.uniq
+ cr_children = {}
+ if active_cr_containers.any?
+ active_cr_containers.each { |c| cr_children[c] = []}
+ cols = ContainerRequest.columns.map(&:name) - %w(id updated_at mounts)
+ reqs = ContainerRequest.select(cols).where(requesting_container_uuid: active_cr_containers).results
+ reqs.each {|cr| cr_children[cr.requesting_container_uuid] << cr} if reqs
+ end
+
wus = {}
outputs = []
recent_procs.each do |p|
- wu = p.work_unit
+ if p.uuid.in?(active_cr_uuids)
+ wu = p.work_unit(nil, child_objects=cr_children[p.container_uuid])
+ else
+ wu = p.work_unit
+ end
+
wus[p] = wu
outputs << wu.outputs
end
-----------------------------------------------------------------------
hooks/post-receive
--
More information about the arvados-commits
mailing list