Merge branch 'master' into 13822-nm-delayed-daemon
[arvados.git] / services / api / test / functional / application_controller_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 ApplicationControllerTest < ActionController::TestCase
8   BAD_UUID = "zzzzz-zzzzz-zzzzzzzzzzzzzzz"
9
10   def now_timestamp
11     Time.now.utc.to_i
12   end
13
14   setup do
15     # These tests are meant to check behavior in ApplicationController.
16     # We instantiate a small concrete controller for convenience.
17     @controller = Arvados::V1::SpecimensController.new
18     @start_stamp = now_timestamp
19   end
20
21   def check_error_token
22     token = json_response['error_token']
23     assert_not_nil token
24     token_time = token.split('+', 2).first.to_i
25     assert_operator(token_time, :>=, @start_stamp, "error token too old")
26     assert_operator(token_time, :<=, now_timestamp, "error token too new")
27   end
28
29   def check_404(errmsg="Path not found")
30     assert_response 404
31     assert_equal([errmsg], json_response['errors'])
32     check_error_token
33   end
34
35   test "requesting nonexistent object returns 404 error" do
36     authorize_with :admin
37     get(:show, id: BAD_UUID)
38     check_404
39   end
40
41   test "requesting object without read permission returns 404 error" do
42     authorize_with :spectator
43     get(:show, id: specimens(:owned_by_active_user).uuid)
44     check_404
45   end
46
47   test "submitting bad object returns error" do
48     authorize_with :spectator
49     post(:create, specimen: {badattr: "badvalue"})
50     assert_response 422
51     check_error_token
52   end
53
54   test "X-Request-Id header" do
55     authorize_with :spectator
56     get(:index)
57     assert_match /^req-[0-9a-zA-Z]{20}$/, response.headers['X-Request-Id']
58   end
59
60   # The response header is the one that gets logged, so this test also
61   # ensures we log the ID supplied in the request, if any.
62   test "X-Request-Id given by client" do
63     authorize_with :spectator
64     @request.headers['X-Request-Id'] = 'abcdefG'
65     get(:index)
66     assert_equal 'abcdefG', response.headers['X-Request-Id']
67   end
68
69   test "X-Request-Id given by client is ignored if too long" do
70     authorize_with :spectator
71     @request.headers['X-Request-Id'] = 'abcdefG' * 1000
72     get(:index)
73     assert_match /^req-[0-9a-zA-Z]{20}$/, response.headers['X-Request-Id']
74   end
75
76   ['foo', '', 'FALSE', 'TRUE', nil, [true], {a:true}, '"true"'].each do |bogus|
77     test "bogus boolean parameter #{bogus.inspect} returns error" do
78       @controller = Arvados::V1::GroupsController.new
79       authorize_with :active
80       post :create, {
81         group: {},
82         ensure_unique_name: bogus
83       }
84       assert_response 422
85       assert_match(/parameter must be a boolean/, json_response['errors'].first,
86                    'Helpful error message not found')
87     end
88   end
89
90   [[true, [true, 'true', 1, '1']],
91    [false, [false, 'false', 0, '0']]].each do |bool, boolparams|
92     boolparams.each do |boolparam|
93       # Ensure boolparam is acceptable as a boolean
94       test "boolean parameter #{boolparam.inspect} acceptable" do
95         @controller = Arvados::V1::GroupsController.new
96         authorize_with :active
97         post :create, {
98           group: {},
99           ensure_unique_name: boolparam
100         }
101         assert_response :success
102       end
103
104       # Ensure boolparam is acceptable as the _intended_ boolean
105       test "boolean parameter #{boolparam.inspect} accepted as #{bool.inspect}" do
106         @controller = Arvados::V1::GroupsController.new
107         authorize_with :active
108         post :create, {
109           group: {
110             name: groups(:aproject).name,
111             owner_uuid: groups(:aproject).owner_uuid
112           },
113           ensure_unique_name: boolparam
114         }
115         assert_response (bool ? :success : 422)
116       end
117     end
118   end
119 end