1 # Copyright (C) The Arvados Authors. All rights reserved.
3 # SPDX-License-Identifier: AGPL-3.0
7 class GroupsTest < ActionDispatch::IntegrationTest
8 [[], ['replication_confirmed']].each do |orders|
9 test "results are consistent when provided orders #{orders} is incomplete" do
12 get '/arvados/v1/groups/contents',
14 id: groups(:aproject).uuid,
15 filters: [["uuid", "is_a", "arvados#collection"]].to_json,
16 orders: orders.to_json,
19 headers: auth(:active)
20 assert_response :success
22 last = json_response['items']
24 assert_equal last, json_response['items']
30 test "get all pages of group-owned objects" do
37 get "/arvados/v1/groups/contents",
39 id: groups(:aproject).uuid,
44 headers: auth(:active)
46 assert_response :success
47 assert_operator(0, :<, json_response['items'].count,
48 "items_available=#{items_available} but received 0 "\
49 "items with offset=#{offset}")
50 items_available ||= json_response['items_available']
51 assert_equal(items_available, json_response['items_available'],
52 "items_available changed between page #{offset/limit} "\
53 "and page #{1+offset/limit}")
54 json_response['items'].each do |item|
56 assert_equal(nil, uuid_received[uuid],
57 "Received '#{uuid}' again on page #{1+offset/limit}")
58 uuid_received[uuid] = true
59 owner_received[item['owner_uuid']] = true
61 assert_equal groups(:aproject).uuid, item['owner_uuid']
63 break if offset >= items_available
68 ['Collection_', true], # collections and pipelines templates
69 ['hash', true], # pipeline templates
70 ['fa7aeb5140e2848d39b', false], # script_parameter of pipeline instances
71 ['fa7aeb5140e2848d39b:*', true], # script_parameter of pipeline instances
72 ['project pipeline', true], # finds "Completed pipeline in A Project"
73 ['project pipeli:*', true], # finds "Completed pipeline in A Project"
74 ['proje pipeli:*', false], # first word is incomplete, so no prefix match
75 ['no-such-thing', false], # script_parameter of pipeline instances
76 ].each do |search_filter, expect_results|
77 test "full text search of group-owned objects for #{search_filter}" do
78 get "/arvados/v1/groups/contents",
80 id: groups(:aproject).uuid,
82 :filters => [['any', '@@', search_filter]].to_json
84 headers: auth(:active)
85 assert_response :success
87 refute_empty json_response['items']
88 json_response['items'].each do |item|
90 assert_equal groups(:aproject).uuid, item['owner_uuid']
93 assert_empty json_response['items']
98 test "full text search is not supported for individual columns" do
99 get "/arvados/v1/groups/contents",
101 :filters => [['name', '@@', 'Private']].to_json
103 headers: auth(:active)
107 test "group contents with include trash collections" do
108 get "/arvados/v1/groups/contents",
110 include_trash: "true",
111 filters: [["uuid", "is_a", "arvados#collection"]].to_json,
114 headers: auth(:active)
118 json_response['items'].each { |c| coll_uuids << c['uuid'] }
119 assert_includes coll_uuids, collections(:foo_collection_in_aproject).uuid
120 assert_includes coll_uuids, collections(:expired_collection).uuid
123 test "group contents without trash collections" do
124 get "/arvados/v1/groups/contents",
126 filters: [["uuid", "is_a", "arvados#collection"]].to_json,
129 headers: auth(:active)
133 json_response['items'].each { |c| coll_uuids << c['uuid'] }
134 assert_includes coll_uuids, collections(:foo_collection_in_aproject).uuid
135 assert_not_includes coll_uuids, collections(:expired_collection).uuid
139 class NonTransactionalGroupsTest < ActionDispatch::IntegrationTest
140 # Transactional tests are disabled to be able to test the concurrent
141 # asynchronous permissions update feature.
142 # This is needed because nested transactions share the connection pool, so
143 # one thread is locked while trying to talk to the database, until the other
145 self.use_transactional_tests = false
148 # Explicitly reset the database after each test.
149 post '/database/reset', params: {}, headers: auth(:admin)
150 assert_response :success
153 test "create request with async=true defers permissions update" do
154 Rails.configuration.async_permissions_update_interval = 1 # second
155 name = "Random group #{rand(1000)}"
156 assert_equal nil, Group.find_by_name(name)
158 # Trigger the asynchronous permission update by using async=true parameter.
159 post "/arvados/v1/groups",
166 headers: auth(:active)
169 # The group exists on the database, but it's not accessible yet.
170 assert_not_nil Group.find_by_name(name)
171 get "/arvados/v1/groups",
173 filters: [["name", "=", name]].to_json,
176 headers: auth(:active)
178 assert_equal 0, json_response['items_available']
180 # Wait a bit and try again.
182 get "/arvados/v1/groups",
184 filters: [["name", "=", name]].to_json,
187 headers: auth(:active)
189 assert_equal 1, json_response['items_available']