1 # Copyright (C) The Arvados Authors. All rights reserved.
3 # SPDX-License-Identifier: AGPL-3.0
7 class WorkUnitTest < ActiveSupport::TestCase
9 reset_api_fixtures :after_each_test, false
12 Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token']
16 [Job, 'running_job_with_components', "jwu", 2, "Running", nil, 0.5],
17 [PipelineInstance, 'pipeline_in_running_state', nil, 1, "Running", nil, 0.0],
18 [PipelineInstance, 'has_component_with_completed_jobs', nil, 3, "Complete", true, 1.0],
19 [PipelineInstance, 'pipeline_with_tagged_collection_input', "pwu", 1, "Ready", nil, 0.0],
20 [PipelineInstance, 'failed_pipeline_with_two_jobs', nil, 2, "Cancelled", false, 0.0],
21 [Container, 'requester', 'cwu', 1, "Complete", true, 1.0],
22 [ContainerRequest, 'cr_for_requester', 'cwu', 1, "Complete", true, 1.0],
23 [ContainerRequest, 'queued', 'cwu', 0, "Queued", nil, 0.0], # priority 1
24 [ContainerRequest, 'canceled_with_queued_container', 'cwu', 0, "Cancelled", false, 0.0],
25 [ContainerRequest, 'canceled_with_locked_container', 'cwu', 0, "Cancelled", false, 0.0],
26 [ContainerRequest, 'canceled_with_running_container', 'cwu', 1, "Running", nil, 0.0],
27 ].each do |type, fixture, label, num_children, state, success, progress|
28 test "children of #{fixture}" do
30 obj = find_fixture(type, fixture)
31 wu = obj.work_unit(label)
34 assert_equal(label, wu.label)
38 assert_equal(obj.name, wu.label)
40 assert_equal(obj['uuid'], wu.uuid)
41 assert_equal(state, wu.state_label)
43 assert_nil(wu.success?)
45 assert_equal(success, wu.success?)
47 assert_equal(progress, wu.progress)
49 assert_equal(num_children, wu.children.size)
50 wu.children.each do |child|
51 assert_equal(true, child.respond_to?(:script))
57 ['cr_for_failed', 'Failed', 33],
58 ['completed', 'Complete', 0],
59 ].each do |cr_fixture, state, exit_code|
60 test "Completed ContainerRequest state = #{state} with exit_code = #{exit_code}" do
62 obj = find_fixture(ContainerRequest, cr_fixture)
64 assert_equal state, wu.state_label
65 assert_equal exit_code, wu.exit_code
70 [Job, 'running_job_with_components', 1, 1, nil, true],
71 [Job, 'queued', nil, 0, 1, false],
72 [PipelineInstance, 'pipeline_in_running_state', 1, 1, nil, false],
73 [PipelineInstance, 'has_component_with_completed_jobs', 60, 60, nil, true],
74 ].each do |type, fixture, walltime, cputime, queuedtime, cputime_more_than_walltime|
75 test "times for #{fixture}" do
77 obj = find_fixture(type, fixture)
81 assert_equal true, (wu.walltime >= walltime)
84 assert_nil wu.walltime
86 assert_equal walltime, wu.walltime
91 assert_equal true, (wu.cputime >= cputime)
93 assert_equal cputime, wu.cputime
97 assert_equal true, (wu.queuedtime >= queuedtime)
99 assert_nil wu.queuedtime
101 assert_equal queuedtime, wu.queuedtime
104 assert_equal cputime_more_than_walltime, (wu.cputime > wu.walltime) if wu.cputime and wu.walltime
108 test 'can_cancel?' do
109 use_token 'active' do
110 assert find_fixture(Job, 'running').work_unit.can_cancel?
111 refute find_fixture(Container, 'running').work_unit.can_cancel?
112 assert find_fixture(ContainerRequest, 'running').work_unit.can_cancel?
114 use_token 'spectator' do
115 refute find_fixture(ContainerRequest, 'running_anonymous_accessible').work_unit.can_cancel?
118 assert find_fixture(ContainerRequest, 'running_anonymous_accessible').work_unit.can_cancel?