X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/ea17ec3d053bd2f792730c5ea74d03109ef942ce..63330000144108862a4e2b02a7a8fa124d01163e:/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 db2a467b7e..396d750d30 100644 --- a/apps/workbench/app/helpers/pipeline_instances_helper.rb +++ b/apps/workbench/app/helpers/pipeline_instances_helper.rb @@ -22,28 +22,32 @@ module PipelineInstancesHelper pj end - def pipieline_log_history(job_uuids) - results = [] - - log_history = Log.where(event_type: 'transient-log-entry', - object_uuid: job_uuids).order('id DESC').limit(5).all - if !log_history.results.empty? - results = log_history.results.reverse - end - - return results - end - protected def pipeline_jobs_newschool object ret = [] i = -1 + jobuuids = object.components.values.map { |c| + c[:job][:uuid] if c.is_a?(Hash) and c[:job].is_a?(Hash) + }.compact + job = {} + Job.where(uuid: jobuuids).each do |j| + job[j[:uuid]] = j + end + object.components.each do |cname, c| i += 1 pj = {index: i, name: cname} - pj[:job] = c[:job].is_a?(Hash) ? c[:job] : {} + if not c.is_a?(Hash) + ret << pj + next + end + if c[:job] and c[:job][:uuid] and job[c[:job][:uuid]] + pj[:job] = job[c[:job][:uuid]] + else + pj[:job] = c[:job].is_a?(Hash) ? c[:job] : {} + end pj[:percent_done] = 0 pj[:percent_running] = 0 if pj[:job][:success] @@ -73,17 +77,22 @@ module PipelineInstancesHelper end if pj[:job][:success] pj[:result] = 'complete' + pj[:labeltype] = 'success' pj[:complete] = true pj[:progress] = 1.0 elsif pj[:job][:finished_at] pj[:result] = 'failed' + pj[:labeltype] = 'danger' pj[:failed] = true elsif pj[:job][:started_at] pj[:result] = 'running' + pj[:labeltype] = 'primary' elsif pj[:job][:uuid] pj[:result] = 'queued' + pj[:labeltype] = 'default' else pj[:result] = 'none' + pj[:labeltype] = 'default' end pj[:job_id] = pj[:job][:uuid] pj[:script] = pj[:job][:script] || c[:script]