X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/f6b88a9e7e9727f0397f1febbad8c08f6a20463d..5b863886118890cc81b728a3a606ea823c836f2b:/services/api/test/integration/groups_test.rb diff --git a/services/api/test/integration/groups_test.rb b/services/api/test/integration/groups_test.rb index 5ceb99bcb9..6b1bf795ed 100644 --- a/services/api/test/integration/groups_test.rb +++ b/services/api/test/integration/groups_test.rb @@ -1,6 +1,29 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'test_helper' class GroupsTest < ActionDispatch::IntegrationTest + [[], ['replication_confirmed']].each do |orders| + test "results are consistent when provided orders #{orders} is incomplete" do + last = nil + (0..20).each do + get '/arvados/v1/groups/contents', { + id: groups(:aproject).uuid, + filters: [["uuid", "is_a", "arvados#collection"]].to_json, + orders: orders.to_json, + format: :json, + }, auth(:active) + assert_response :success + if last.nil? + last = json_response['items'] + else + assert_equal last, json_response['items'] + end + end + end + end test "get all pages of group-owned objects" do limit = 5 @@ -9,8 +32,6 @@ class GroupsTest < ActionDispatch::IntegrationTest uuid_received = {} owner_received = {} while true - @json_response = nil - get "/arvados/v1/groups/contents", { id: groups(:aproject).uuid, limit: limit, @@ -74,4 +95,63 @@ class GroupsTest < ActionDispatch::IntegrationTest }, auth(:active) assert_response 422 end + + test "group contents with include trash collections" do + get "/arvados/v1/groups/contents", { + include_trash: "true", + filters: [["uuid", "is_a", "arvados#collection"]].to_json, + limit: 1000 + }, auth(:active) + assert_response 200 + + coll_uuids = [] + json_response['items'].each { |c| coll_uuids << c['uuid'] } + assert_includes coll_uuids, collections(:foo_collection_in_aproject).uuid + assert_includes coll_uuids, collections(:expired_collection).uuid + end + + test "group contents without trash collections" do + get "/arvados/v1/groups/contents", { + filters: [["uuid", "is_a", "arvados#collection"]].to_json, + limit: 1000 + }, auth(:active) + assert_response 200 + + coll_uuids = [] + json_response['items'].each { |c| coll_uuids << c['uuid'] } + assert_includes coll_uuids, collections(:foo_collection_in_aproject).uuid + assert_not_includes coll_uuids, collections(:expired_collection).uuid + end + + test "create request with async=true defers permissions update" do + Rails.configuration.async_permissions_update_interval = 1 # seconds + name = "Random group #{rand(1000)}" + assert_equal nil, Group.find_by_name(name) + post "/arvados/v1/groups", { + group: { + name: name + }, + async: true + }, auth(:active) + assert_response 202 + g = Group.find_by_name(name) + assert_not_nil g + get "/arvados/v1/groups", { + filters: [["name", "=", name]].to_json, + limit: 10 + }, auth(:active) + assert_response 200 + assert_equal 0, json_response['items_available'] + + # Unblock the thread doing the permissions update + ActiveRecord::Base.clear_active_connections! + + sleep(3) + get "/arvados/v1/groups", { + filters: [["name", "=", name]].to_json, + limit: 10 + }, auth(:active) + assert_response 200 + assert_equal 1, json_response['items_available'] + end end