X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/a4f061a5bf48f0335238da72b8d03ca349fa7553..f30e59af90558e47a4156566d0209bc8efacd85a:/apps/workbench/app/models/pipeline_instance_work_unit.rb diff --git a/apps/workbench/app/models/pipeline_instance_work_unit.rb b/apps/workbench/app/models/pipeline_instance_work_unit.rb index 9d6db39572..1d75f58433 100644 --- a/apps/workbench/app/models/pipeline_instance_work_unit.rb +++ b/apps/workbench/app/models/pipeline_instance_work_unit.rb @@ -1,14 +1,20 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + class PipelineInstanceWorkUnit < ProxyWorkUnit def children + return @my_children if @my_children + items = [] jobs = {} - results = Job.where(uuid: self.proxied.job_ids.values).results + results = Job.where(uuid: @proxied.job_ids.values).with_count("none").results results.each do |j| jobs[j.uuid] = j end - components = (self.proxied.components if self.proxied.respond_to?(:components)) || self.proxied[:components] + components = get(:components) components.each do |name, c| if c.is_a?(Hash) job = c[:job] @@ -16,56 +22,59 @@ class PipelineInstanceWorkUnit < ProxyWorkUnit if job[:uuid] and jobs[job[:uuid]] items << jobs[job[:uuid]].work_unit(name) else - items << JobWorkUnit.new(job, name) + items << JobWorkUnit.new(job, name, uuid) end else - items << ProxyWorkUnit.new(c, name) + items << JobWorkUnit.new(c, name, uuid) end else + @unreadable_children = true break end end - items + @my_children = items end - def progress - state = (self.proxied.state if self.proxied.respond_to?(:state)) || self.proxied[:state] - if state == 'Complete' - return 1.0 - end - - done = 0 - failed = 0 - todo = 0 - children.each do |c| - if c.success?.nil? - todo = todo+1 - elsif c.success? - done = done+1 - else - failed = failed+1 + def outputs + items = [] + components = get(:components) + components.each do |name, c| + if c.is_a?(Hash) + items << c[:output_uuid] if c[:output_uuid] end end - - if done + failed + todo > 0 - total = done + failed + todo - (done+failed).to_f / total - else - 0.0 - end - end - - def can_cancel? - true + items end def uri - uuid = (self.proxied.uuid if self.proxied.respond_to?(:uuid)) || self.proxied[:uuid] + uuid = get(:uuid) "/pipeline_instances/#{uuid}" end def title "pipeline" end + + def template_uuid + get(:pipeline_template_uuid) + end + + def state_label + if get(:state) != "Failed" + return super + end + if get(:components_summary).andand[:failed].andand > 0 + return super + end + # Show "Cancelled" instead of "Failed" if there are no failed + # components. #12840 + get(:components).each do |_, c| + jstate = c[:job][:state] rescue nil + if jstate == "Failed" + return "Failed" + end + end + "Cancelled" + end end