X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/607fe087f6167061714a524dd53cbbc21b974973..28b6afc1e8ccf652c7a8fd43e22a8ac788febd85:/apps/workbench/app/models/proxy_work_unit.rb diff --git a/apps/workbench/app/models/proxy_work_unit.rb b/apps/workbench/app/models/proxy_work_unit.rb index b7cc6a0f19..adf0bd7d67 100644 --- a/apps/workbench/app/models/proxy_work_unit.rb +++ b/apps/workbench/app/models/proxy_work_unit.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + class ProxyWorkUnit < WorkUnit require 'time' @@ -222,14 +226,26 @@ class ProxyWorkUnit < WorkUnit state_label == 'Failed' end - def show_runtime - runningtime = ApplicationController.helpers.determine_wallclock_runtime(if children.any? then children else [self] end) + def runtime_contributors + contributors = [] + if children.any? + children.each{|c| contributors << c.runtime_contributors} + else + contributors << self + end + contributors.flatten + end + + def runningtime + ApplicationController.helpers.determine_wallclock_runtime runtime_contributors + end + def show_runtime walltime = 0 + running_time = runningtime if started_at walltime = if finished_at then (finished_at - started_at) else (Time.now - started_at) end end - resp = '

' if started_at @@ -239,16 +255,14 @@ class ProxyWorkUnit < WorkUnit if state_label == 'Complete' resp << "completed in " elsif state_label == 'Failed' - resp << "failed after " + resp << "failed after " + elsif state_label == 'Cancelled' + resp << "was cancelled after " else resp << "has been active for " end - if walltime > runningtime - resp << ApplicationController.helpers.render_time(walltime, false) - else - resp << ApplicationController.helpers.render_time(runningtime, false) - end + resp << ApplicationController.helpers.render_time(walltime, false) if finished_at resp << " at " @@ -264,26 +278,24 @@ class ProxyWorkUnit < WorkUnit end if is_failed? - resp << " Check the Log tab for more detail about why it failed." + if runtime_status.andand[:error] + resp << " Check the error information below." + else + resp << " Check the Log tab for more detail about why it failed." + end end resp << "

" resp << "

" if state_label - resp << "It " - if state_label == 'Running' - resp << "has run" - else - resp << "ran" - end - resp << " for " + resp << "It has runtime of " cpu_time = cputime - resp << ApplicationController.helpers.render_time(runningtime, false) - if (walltime - runningtime) > 0 + resp << ApplicationController.helpers.render_time(running_time, false) + if (walltime - running_time) > 0 resp << "(" - resp << ApplicationController.helpers.render_time(walltime - runningtime, false) + resp << ApplicationController.helpers.render_time(walltime - running_time, false) resp << "queued)" end if cpu_time == 0 @@ -292,7 +304,7 @@ class ProxyWorkUnit < WorkUnit resp << " and used " resp << ApplicationController.helpers.render_time(cpu_time, false) resp << " of node allocation time (" - resp << (cpu_time/runningtime).round(1).to_s + resp << (cpu_time/running_time).round(1).to_s resp << "⨯ scaling)." end end