7475: Merge branch 'master' into 7475-nodemgr-unsatisfiable-job-comms
[arvados.git] / apps / workbench / test / unit / work_unit_test.rb
1 # Copyright (C) The Arvados Authors. All rights reserved.
2 #
3 # SPDX-License-Identifier: AGPL-3.0
4
5 require 'test_helper'
6
7 class WorkUnitTest < ActiveSupport::TestCase
8
9   reset_api_fixtures :after_each_test, false
10
11   setup do
12     Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token']
13   end
14
15   [
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     [Container, 'requester', 'cwu', 1, "Complete", true, 1.0],
21     [ContainerRequest, 'cr_for_requester', 'cwu', 1, "Complete", true, 1.0],
22     [ContainerRequest, 'queued', 'cwu', 0, "Queued", nil, 0.0],   # priority 1
23     [ContainerRequest, 'canceled_with_queued_container', 'cwu', 0, "Cancelled", false, 0.0],
24     [ContainerRequest, 'canceled_with_locked_container', 'cwu', 0, "Queued", nil, 0.0],
25     [ContainerRequest, 'canceled_with_running_container', 'cwu', 1, "Running", nil, 0.0],
26   ].each do |type, fixture, label, num_children, state, success, progress|
27     test "children of #{fixture}" do
28       use_token 'active'
29       obj = find_fixture(type, fixture)
30       wu = obj.work_unit(label)
31
32       if label != nil
33         assert_equal(label, wu.label)
34       else
35         assert_equal(obj.name, wu.label)
36       end
37       assert_equal(obj['uuid'], wu.uuid)
38       assert_equal(state, wu.state_label)
39       assert_equal(success, wu.success?)
40       assert_equal(progress, wu.progress)
41
42       assert_equal(num_children, wu.children.size)
43       wu.children.each do |child|
44         assert_equal(true, child.respond_to?(:script))
45       end
46     end
47   end
48
49   [
50     ['cr_for_failed', 'Failed', 33],
51     ['completed', 'Complete', 0],
52   ].each do |cr_fixture, state, exit_code|
53     test "Completed ContainerRequest state = #{state} with exit_code = #{exit_code}" do
54       use_token 'active'
55       obj = find_fixture(ContainerRequest, cr_fixture)
56       wu = obj.work_unit
57       assert_equal state, wu.state_label
58       assert_equal exit_code, wu.exit_code
59     end
60   end
61
62   [
63     [Job, 'running_job_with_components', 1, 1, nil, true],
64     [Job, 'queued', nil, 0, 1, false],
65     [PipelineInstance, 'pipeline_in_running_state', 1, 1, nil, false],
66     [PipelineInstance, 'has_component_with_completed_jobs', 60, 60, nil, true],
67   ].each do |type, fixture, walltime, cputime, queuedtime, cputime_more_than_walltime|
68     test "times for #{fixture}" do
69       use_token 'active'
70       obj = find_fixture(type, fixture)
71       wu = obj.work_unit
72
73       if walltime
74         assert_equal true, (wu.walltime >= walltime)
75       else
76         assert_equal walltime, wu.walltime
77       end
78
79       if cputime
80         assert_equal true, (wu.cputime >= cputime)
81       else
82         assert_equal cputime, wu.cputime
83       end
84
85       if queuedtime
86         assert_equal true, (wu.queuedtime >= queuedtime)
87       else
88         assert_equal queuedtime, wu.queuedtime
89       end
90
91       assert_equal cputime_more_than_walltime, (wu.cputime > wu.walltime) if wu.cputime and wu.walltime
92     end
93   end
94
95   test 'can_cancel?' do
96     use_token 'active' do
97       assert find_fixture(Job, 'running').work_unit.can_cancel?
98       refute find_fixture(Container, 'running').work_unit.can_cancel?
99       assert find_fixture(ContainerRequest, 'running').work_unit.can_cancel?
100     end
101     use_token 'spectator' do
102       refute find_fixture(ContainerRequest, 'running_anonymous_accessible').work_unit.can_cancel?
103     end
104     use_token 'admin' do
105       assert find_fixture(ContainerRequest, 'running_anonymous_accessible').work_unit.can_cancel?
106     end
107   end
108 end