X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/43c411ec1441ee1710dc33389d7451f7414a170f..7e44e7ea12b604b8823c24f468c33e9f33fb6e5f:/apps/workbench/app/helpers/pipeline_instances_helper.rb diff --git a/apps/workbench/app/helpers/pipeline_instances_helper.rb b/apps/workbench/app/helpers/pipeline_instances_helper.rb index c792db8512..fbce7f550b 100644 --- a/apps/workbench/app/helpers/pipeline_instances_helper.rb +++ b/apps/workbench/app/helpers/pipeline_instances_helper.rb @@ -1,18 +1,36 @@ module PipelineInstancesHelper - def pipeline_jobs - if @object.components[:steps].is_a? Array - pipeline_jobs_oldschool - elsif @object.components.is_a? Hash - pipeline_jobs_newschool + def pipeline_jobs object=nil + object ||= @object + if object.components[:steps].is_a? Array + pipeline_jobs_oldschool object + elsif object.components.is_a? Hash + pipeline_jobs_newschool object end end + def render_pipeline_jobs + pipeline_jobs.collect do |pj| + render_pipeline_job pj + end + end + + def render_pipeline_job pj + if pj[:percent_done] + pj[:progress_bar] = raw("
") + elsif pj[:progress] + raw("
") + end + pj[:output_link] = link_to_if_arvados_object pj[:output] + pj[:job_link] = link_to_if_arvados_object pj[:job][:uuid] + pj + end + protected - def pipeline_jobs_newschool + def pipeline_jobs_newschool object ret = [] i = -1 - @object.components.each do |cname, c| + object.components.each do |cname, c| i += 1 pj = {index: i, name: cname} pj[:job] = c[:job].is_a?(Hash) ? c[:job] : {} @@ -43,35 +61,33 @@ module PipelineInstancesHelper pj[:progress] = 0.0 end end - if pj[:job] - if pj[:job][:success] - pj[:result] = 'complete' - pj[:complete] = true - pj[:progress] = 1.0 - elsif pj[:job][:finished_at] - pj[:result] = 'failed' - pj[:failed] = true - elsif pj[:job][:started_at] - pj[:result] = 'running' - else - pj[:result] = 'queued' - end + if pj[:job][:success] + pj[:result] = 'complete' + pj[:complete] = true + pj[:progress] = 1.0 + elsif pj[:job][:finished_at] + pj[:result] = 'failed' + pj[:failed] = true + elsif pj[:job][:started_at] + pj[:result] = 'running' + elsif pj[:job][:uuid] + pj[:result] = 'queued' + else + pj[:result] = 'none' end pj[:job_id] = pj[:job][:uuid] - pj[:job_link] = link_to_if_arvados_object pj[:job][:uuid] - pj[:script_version] = pj[:job][:script_version] + pj[:script] = pj[:job][:script] || c[:script] + pj[:script_version] = pj[:job][:script_version] || c[:script_version] pj[:output] = pj[:job][:output] pj[:finished_at] = (Time.parse(pj[:job][:finished_at]) rescue nil) - pj[:progress_bar] = raw("
") - pj[:output_link] = link_to_if_arvados_object pj[:output] ret << pj end ret end - def pipeline_jobs_oldschool + def pipeline_jobs_oldschool object ret = [] - @object.components[:steps].each_with_index do |step, i| + object.components[:steps].each_with_index do |step, i| pj = {index: i, name: step[:name]} if step[:complete] and step[:complete] != 0 if step[:output_data_locator] @@ -112,8 +128,6 @@ module PipelineInstancesHelper pj[:script_version] = (step[:warehousejob][:revision] rescue nil) pj[:output] = step[:output_data_locator] pj[:finished_at] = (Time.parse(step[:warehousejob][:finishtime]) rescue nil) - pj[:progress_bar] = raw("
") - pj[:output_link] = link_to_if_arvados_object pj[:output] ret << pj end ret