X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/570509ab4d2ef93d870fd2b1f2eab178afb1bad9..8cd99fc692479db9c2aaa211d34ce7d62df47328:/apps/workbench/test/unit/work_unit_test.rb diff --git a/apps/workbench/test/unit/work_unit_test.rb b/apps/workbench/test/unit/work_unit_test.rb index 0ff38140e1..eaf65c578d 100644 --- a/apps/workbench/test/unit/work_unit_test.rb +++ b/apps/workbench/test/unit/work_unit_test.rb @@ -1,6 +1,13 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'test_helper' class WorkUnitTest < ActiveSupport::TestCase + + reset_api_fixtures :after_each_test, false + setup do Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token'] end @@ -10,11 +17,12 @@ class WorkUnitTest < ActiveSupport::TestCase [PipelineInstance, 'pipeline_in_running_state', nil, 1, "Running", nil, 0.0], [PipelineInstance, 'has_component_with_completed_jobs', nil, 3, "Complete", true, 1.0], [PipelineInstance, 'pipeline_with_tagged_collection_input', "pwu", 1, "Ready", nil, 0.0], + [PipelineInstance, 'failed_pipeline_with_two_jobs', nil, 2, "Cancelled", false, 0.0], [Container, 'requester', 'cwu', 1, "Complete", true, 1.0], [ContainerRequest, 'cr_for_requester', 'cwu', 1, "Complete", true, 1.0], [ContainerRequest, 'queued', 'cwu', 0, "Queued", nil, 0.0], # priority 1 - [ContainerRequest, 'canceled_with_queued_container', 'cwu', 0, "Ready", nil, 0.0], - [ContainerRequest, 'canceled_with_locked_container', 'cwu', 0, "Ready", nil, 0.0], + [ContainerRequest, 'canceled_with_queued_container', 'cwu', 0, "Cancelled", false, 0.0], + [ContainerRequest, 'canceled_with_locked_container', 'cwu', 0, "Cancelled", false, 0.0], [ContainerRequest, 'canceled_with_running_container', 'cwu', 1, "Running", nil, 0.0], ].each do |type, fixture, label, num_children, state, success, progress| test "children of #{fixture}" do @@ -24,12 +32,18 @@ class WorkUnitTest < ActiveSupport::TestCase if label != nil assert_equal(label, wu.label) + elsif obj.name.nil? + assert_nil(wu.label) else assert_equal(obj.name, wu.label) end assert_equal(obj['uuid'], wu.uuid) assert_equal(state, wu.state_label) - assert_equal(success, wu.success?) + if success.nil? + assert_nil(wu.success?) + else + assert_equal(success, wu.success?) + end assert_equal(progress, wu.progress) assert_equal(num_children, wu.children.size) @@ -53,11 +67,11 @@ class WorkUnitTest < ActiveSupport::TestCase end [ - [Job, 'running_job_with_components', 1, 1, nil], - [Job, 'queued', nil, nil, 1], - [PipelineInstance, 'pipeline_in_running_state', 1, 1, nil], - [PipelineInstance, 'has_component_with_completed_jobs', 60, 60, nil], - ].each do |type, fixture, walltime, cputime, queuedtime| + [Job, 'running_job_with_components', 1, 1, nil, true], + [Job, 'queued', nil, 0, 1, false], + [PipelineInstance, 'pipeline_in_running_state', 1, 1, nil, false], + [PipelineInstance, 'has_component_with_completed_jobs', 60, 60, nil, true], + ].each do |type, fixture, walltime, cputime, queuedtime, cputime_more_than_walltime| test "times for #{fixture}" do use_token 'active' obj = find_fixture(type, fixture) @@ -66,7 +80,11 @@ class WorkUnitTest < ActiveSupport::TestCase if walltime assert_equal true, (wu.walltime >= walltime) else - assert_equal walltime, wu.walltime + if walltime.nil? + assert_nil wu.walltime + else + assert_equal walltime, wu.walltime + end end if cputime @@ -77,9 +95,13 @@ class WorkUnitTest < ActiveSupport::TestCase if queuedtime assert_equal true, (wu.queuedtime >= queuedtime) + elsif queuedtime.nil? + assert_nil wu.queuedtime else assert_equal queuedtime, wu.queuedtime end + + assert_equal cputime_more_than_walltime, (wu.cputime > wu.walltime) if wu.cputime and wu.walltime end end