10111: Added provenance graph for container requests.
authorLucas Di Pentima <lucas@curoverse.com>
Mon, 24 Apr 2017 19:30:00 +0000 (16:30 -0300)
committerLucas Di Pentima <lucas@curoverse.com>
Mon, 24 Apr 2017 19:30:00 +0000 (16:30 -0300)
apps/workbench/app/controllers/container_requests_controller.rb
apps/workbench/app/helpers/provenance_helper.rb
apps/workbench/app/views/container_requests/_show_provenance.html.erb [new file with mode: 0644]

index b286a9456e14e3a2538df122c31e6071fab33558..817f8824d8c5613b25e7b3c97f4f688f75988fb8 100644 (file)
@@ -4,14 +4,32 @@ class ContainerRequestsController < ApplicationController
     'show' == ctrl.action_name
   }
 
+  def generate_provenance(cr)
+    return if params['tab_pane'] != "Provenance"
+
+    nodes = {}
+    nodes[cr[:uuid]] = cr
+    @svg = ProvenanceHelper::create_provenance_graph nodes,
+                                                     "provenance_svg",
+                                                     {
+                                                       :request => request,
+                                                       :direction => :top_down,
+                                                     }
+  end
+
   def show_pane_list
-    panes = %w(Status Log Advanced)
+    panes = %w(Status Log Provenance Advanced)
     if @object.andand.state == 'Uncommitted'
-      panes = %w(Inputs) + panes - %w(Log)
+      panes = %w(Inputs) + panes - %w(Log Provenance)
     end
     panes
   end
 
+  def show
+    generate_provenance(@object)
+    super
+  end
+
   def cancel
     @object.update_attributes! priority: 0
     if params[:return_to]
index a4723a3ec16848d4eb2cd46dab2ea61d783a2bef..31d0203c24adbc8a7cc8967b075a44005dbe9d0c 100644 (file)
@@ -104,6 +104,53 @@ module ProvenanceHelper
       gr
     end
 
+    def cr_edges cr
+      uuid = cr[:uuid]
+      gr = ""
+
+      ProvenanceHelper::find_collections cr[:mounts], 'mounts' do |col_hash, col_uuid, key|
+        if col_uuid
+          gr += describe_node(col_uuid)
+          gr += edge(col_uuid, uuid, {:label => key})
+        else
+          gr += describe_node(col_hash)
+          gr += edge(col_hash, uuid, {:label => key})
+        end
+      end
+
+      [
+        [true, :requesting_container_uuid, 'requesting_container'],
+        [true, :container_image, 'container_image'],
+        [false, :output_uuid, 'output'],
+        [false, :log_uuid, 'log']
+      ].each do |is_input, attr, label|
+        if cr[attr]
+          if attr == :container_image && cr[:container_uuid]
+            # Extract the container_image's UUID from the CR's container
+            cont = Container.find(cr[:container_uuid])
+            gr += describe_node(cont[:container_image], {label: cr[attr]})
+            # If container_image, then is_input is true
+            edge_from = cont[:container_image]
+            edge_to = uuid
+          else
+            # Default case
+            gr += describe_node(cr[attr])
+
+            if is_input
+              edge_from = cr[attr]
+              edge_to = uuid
+            else
+              edge_from = uuid
+              edge_to = cr[attr]
+            end
+          end
+          gr += edge(edge_from, edge_to, {label: label})
+        end
+      end
+
+      gr
+    end
+
     def job_edges job, edge_opts={}
       uuid = job_uuid(job)
       gr = ""
@@ -184,6 +231,13 @@ module ProvenanceHelper
         if rsc == Job
           job = @pdata[uuid]
           gr += job_edges job if job
+        elsif rsc == ContainerRequest
+          cr = @pdata[uuid]
+          gr += cr_edges cr if cr
+          gr += describe_node(uuid, {href: {controller: 'container_requests',
+                                            id: uuid},
+                                     label: @pdata[uuid][:name],
+                                     shape: 'oval'})
         end
       end
 
diff --git a/apps/workbench/app/views/container_requests/_show_provenance.html.erb b/apps/workbench/app/views/container_requests/_show_provenance.html.erb
new file mode 100644 (file)
index 0000000..253af56
--- /dev/null
@@ -0,0 +1,4 @@
+<%= render partial: 'application/svg_div', locals: {
+      divId: "provenance_graph", 
+      svgId: "provenance_svg", 
+      svg: @svg } %>