X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2129d0fd84fa62a5498d9860f3307cd64dc2a704..324dc9f33d95cdeacf23c0570607900be945d20f:/apps/workbench/app/controllers/pipeline_instances_controller.rb diff --git a/apps/workbench/app/controllers/pipeline_instances_controller.rb b/apps/workbench/app/controllers/pipeline_instances_controller.rb index a42a734394..42cb2e9d44 100644 --- a/apps/workbench/app/controllers/pipeline_instances_controller.rb +++ b/apps/workbench/app/controllers/pipeline_instances_controller.rb @@ -3,25 +3,17 @@ class PipelineInstancesController < ApplicationController before_filter :find_objects_by_uuid, only: :compare include PipelineInstancesHelper - def show - @pipelines = [@object] - - if params[:compare] - PipelineInstance.where(uuid: params[:compare]).each do |p| - @pipelines << p - end - end - + def graph(pipelines) count = {} provenance = {} pips = {} n = 1 - @pipelines.each do |p| + pipelines.each do |p| collections = [] p.components.each do |k, v| - j = v[:job] + j = v[:job] || next uuid = j[:uuid].intern provenance[uuid] = j @@ -39,7 +31,7 @@ class PipelineInstancesController < ApplicationController pips[uuid] |= n end - Collection.where(uuid: collections).each do |c| + Collection.where(uuid: collections.compact).each do |c| uuid = c.uuid.intern provenance[uuid] = c pips[uuid] = 0 unless pips[uuid] != nil @@ -49,11 +41,26 @@ class PipelineInstancesController < ApplicationController n = n << 1 end + return provenance, pips + end + + def show + @pipelines = [@object] + + if params[:compare] + PipelineInstance.where(uuid: params[:compare]).each do |p| + @pipelines << p + end + end + + provenance, pips = graph(@pipelines) + @prov_svg = ProvenanceHelper::create_provenance_graph provenance, "provenance_svg", { :all_script_parameters => true, :combine_jobs => :script_and_version, :script_version_nodes => true, :pips => pips } + super end def compare @@ -88,10 +95,11 @@ class PipelineInstancesController < ApplicationController highscore = {} # attr => how common "normal" is score = {} # attr => { value => how common } row[:components].each do |pj| + next if pj.nil? pj.each do |k,v| vstr = for_comparison v score[k] ||= {} - score[k][vstr] = (score[k][vstr.to_s] || 0) + 1 + score[k][vstr] = (score[k][vstr] || 0) + 1 highscore[k] ||= 0 if score[k][vstr] == highscore[k] # tie for first place = no "normal" @@ -106,14 +114,33 @@ class PipelineInstancesController < ApplicationController # Add a hash in component[:is_normal]: { attr => is_the_value_normal? } row[:components].each do |pj| + next if pj.nil? pj[:is_normal] = {} pj.each do |k,v| pj[:is_normal][k] = (normal.has_key?(k) && normal[k] == for_comparison(v)) end end end + + provenance, pips = graph(@objects) + + @pipelines = @objects + + @prov_svg = ProvenanceHelper::create_provenance_graph provenance, "provenance_svg", { + :all_script_parameters => true, + :combine_jobs => :script_and_version, + :script_version_nodes => true, + :pips => pips } + end + + def show_pane_list + %w(Components Graph Attributes Metadata JSON API) end + def compare_pane_list + %w(Compare Graph) + end + protected def for_comparison v if v.is_a? Hash or v.is_a? Array