9687: Updated state_label method changes to something more simple and compact. Added...
[arvados.git] / apps / workbench / test / unit / work_unit_test.rb
1 require 'test_helper'
2
3 class WorkUnitTest < ActiveSupport::TestCase
4   setup do
5     Rails.configuration.anonymous_user_token = api_fixture('api_client_authorizations')['anonymous']['api_token']
6   end
7
8   [
9     [Job, 'running_job_with_components', "jwu", 2, "Running", nil, 0.5],
10     [PipelineInstance, 'pipeline_in_running_state', nil, 1, "Running", nil, 0.0],
11     [PipelineInstance, 'has_component_with_completed_jobs', nil, 3, "Complete", true, 1.0],
12     [PipelineInstance, 'pipeline_with_tagged_collection_input', "pwu", 1, "Ready", nil, 0.0],
13     [Container, 'requester', 'cwu', 1, "Complete", true, 1.0],
14     [ContainerRequest, 'cr_for_requester', 'cwu', 1, "Complete", true, 1.0],
15   ].each do |type, fixture, label, num_children, state, success, progress|
16     test "children of #{fixture}" do
17       use_token 'active'
18       obj = find_fixture(type, fixture)
19       wu = obj.work_unit(label)
20
21       if label != nil
22         assert_equal(label, wu.label)
23       else
24         assert_equal(obj.name, wu.label)
25       end
26       assert_equal(obj['uuid'], wu.uuid)
27       assert_equal(state, wu.state_label)
28       assert_equal(success, wu.success?)
29       assert_equal(progress, wu.progress)
30
31       assert_equal(num_children, wu.children.size)
32       wu.children.each do |child|
33         assert_equal(true, child.respond_to?(:script))
34       end
35     end
36   end
37
38   [
39     ['cr_for_failed', true],
40     ['completed', false],
41   ].each do |cr_fixture, should_be_Failed|
42     test "state_label of ContainerRequest #{cr_fixture}" do
43       use_token 'active'
44       obj = find_fixture(ContainerRequest, cr_fixture)
45       wu = obj.work_unit
46       assert_equal should_be_Failed, ("Failed" == wu.state_label)
47     end
48   end
49
50   [
51     [Job, 'running_job_with_components', 1, 1, nil],
52     [Job, 'queued', nil, nil, 1],
53     [PipelineInstance, 'pipeline_in_running_state', 1, 1, nil],
54     [PipelineInstance, 'has_component_with_completed_jobs', 60, 60, nil],
55   ].each do |type, fixture, walltime, cputime, queuedtime|
56     test "times for #{fixture}" do
57       use_token 'active'
58       obj = find_fixture(type, fixture)
59       wu = obj.work_unit
60
61       if walltime
62         assert_equal true, (wu.walltime >= walltime)
63       else
64         assert_equal walltime, wu.walltime
65       end
66
67       if cputime
68         assert_equal true, (wu.cputime >= cputime)
69       else
70         assert_equal cputime, wu.cputime
71       end
72
73       if queuedtime
74         assert_equal true, (wu.queuedtime >= queuedtime)
75       else
76         assert_equal queuedtime, wu.queuedtime
77       end
78     end
79   end
80
81   [
82     [Job, 'active', 'running_job_with_components', true],
83     [Job, 'active', 'queued', false],
84     [Job, nil, 'completed_job_in_publicly_accessible_project', true],
85     [Job, 'active', 'completed_job_in_publicly_accessible_project', true],
86     [PipelineInstance, 'active', 'pipeline_in_running_state', true],  # no log, but while running the log link points to pi Log tab
87     [PipelineInstance, nil, 'pipeline_in_publicly_accessible_project_but_other_objects_elsewhere', false],
88     [PipelineInstance, 'active', 'pipeline_in_publicly_accessible_project_but_other_objects_elsewhere', false], #no log for completed pi
89     [Job, nil, 'job_in_publicly_accessible_project_but_other_objects_elsewhere', false, "Log unavailable"],
90   ].each do |type, token, fixture, has_log, log_link|
91     test "link_to_log for #{fixture} for #{token}" do
92       use_token token if token
93       obj = find_fixture(type, fixture)
94       wu = obj.work_unit
95
96       link = "#{wu.uri}#Log" if has_log
97       link_to_log = wu.link_to_log
98
99       if has_log
100         assert_includes link_to_log, link
101       else
102         assert_equal log_link, link_to_log
103       end
104     end
105   end
106 end