X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/397191893819083925600a61e2f355a3b6513354..08d0b1ab43499b7f13462d5e3555d239b4634d22:/services/api/test/unit/user_test.rb diff --git a/services/api/test/unit/user_test.rb b/services/api/test/unit/user_test.rb index b96645ce26..67c410047c 100644 --- a/services/api/test/unit/user_test.rb +++ b/services/api/test/unit/user_test.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'test_helper' class UserTest < ActiveSupport::TestCase @@ -93,6 +97,16 @@ class UserTest < ActiveSupport::TestCase test "new username set with deduplication" do name = users(:active).username check_new_username_setting(name, "#{name}2") + check_new_username_setting(name, "#{name}3") + # Insert some out-of-order conflicts, to ensure our "sort by + # username, stop when we see a hole" strategy doesn't depend on + # insert order. + check_new_username_setting("#{name}13", "#{name}13") + check_new_username_setting("#{name}5", "#{name}5") + check_new_username_setting(name, "#{name}4") + 6.upto(12).each do |n| + check_new_username_setting(name, "#{name}#{n}") + end end test "new username set avoiding blacklist" do @@ -126,7 +140,6 @@ class UserTest < ActiveSupport::TestCase test "admin can't clear username when user owns repositories" do set_user_from_auth :admin user = users(:active) - start_username = user.username user.username = nil assert_not_allowed { user.save } refute_empty(user.errors[:username]) @@ -153,8 +166,8 @@ class UserTest < ActiveSupport::TestCase if auto_admin_first_user_config # This test requires no admin users exist (except for the system user) users(:admin).delete - @all_users = User.where("uuid not like '%-000000000000000'").where(:is_admin => true).find(:all) - assert_equal 0, @all_users.size, "No admin users should exist (except for the system user)" + @all_users = User.where("uuid not like '%-000000000000000'").where(:is_admin => true) + assert_equal 0, @all_users.count, "No admin users should exist (except for the system user)" end Rails.configuration.auto_admin_first_user = auto_admin_first_user_config @@ -267,14 +280,16 @@ class UserTest < ActiveSupport::TestCase assert @uninvited_user.can? :write=>"#{@uninvited_user.uuid}" assert @uninvited_user.can? :manage=>"#{@uninvited_user.uuid}" - assert @uninvited_user.groups_i_can(:read).size == 1, "inactive and uninvited user can only read anonymous user group" - assert @uninvited_user.groups_i_can(:read).first.ends_with? 'anonymouspublic' , "inactive and uninvited user can only read anonymous user group" - assert @uninvited_user.groups_i_can(:write).size == 0, "inactive and uninvited user should not be able write to any groups" - assert @uninvited_user.groups_i_can(:manage).size == 0, "inactive and uninvited user should not be able manage any groups" + assert_equal(@uninvited_user.groups_i_can(:read).sort, + [@uninvited_user.uuid, groups(:anonymous_group).uuid].sort) + assert_equal(@uninvited_user.groups_i_can(:write), + [@uninvited_user.uuid]) + assert_equal(@uninvited_user.groups_i_can(:manage), + [@uninvited_user.uuid]) end test "find user method checks" do - User.find(:all).each do |user| + User.all.each do |user| assert_not_nil user.uuid, "non-null uuid expected for " + user.full_name end @@ -302,14 +317,14 @@ class UserTest < ActiveSupport::TestCase test "create new user" do set_user_from_auth :admin - @all_users = User.find(:all) + @all_users = User.all.to_a user = User.new user.first_name = "first_name_for_newly_created_user" user.save # verify there is one extra user in the db now - assert_equal @all_users.size+1, User.find(:all).size + assert_equal @all_users.size+1, User.all.count user = User.find(user.id) # get the user back assert_equal(user.first_name, 'first_name_for_newly_created_user') @@ -411,7 +426,7 @@ class UserTest < ActiveSupport::TestCase @active_user.delete found_deleted_user = false - User.find(:all).each do |user| + User.all.each do |user| if user.uuid == active_user_uuid found_deleted_user = true break @@ -436,7 +451,9 @@ class UserTest < ActiveSupport::TestCase vm = VirtualMachine.create - response = User.setup user, openid_prefix, 'foo/testrepo', vm.uuid + response = user.setup(openid_prefix: openid_prefix, + repo_name: 'foo/testrepo', + vm_uuid: vm.uuid) resp_user = find_obj_in_resp response, 'User' verify_user resp_user, email @@ -479,7 +496,9 @@ class UserTest < ActiveSupport::TestCase verify_link resp_link, 'permission', 'can_login', email, bad_uuid - response = User.setup user, openid_prefix, 'foo/testrepo', vm.uuid + response = user.setup(openid_prefix: openid_prefix, + repo_name: 'foo/testrepo', + vm_uuid: vm.uuid) resp_user = find_obj_in_resp response, 'User' verify_user resp_user, email @@ -511,7 +530,7 @@ class UserTest < ActiveSupport::TestCase user = User.create ({uuid: 'zzzzz-tpzed-abcdefghijklmno', email: email}) - response = User.setup user, openid_prefix + response = user.setup(openid_prefix: openid_prefix) resp_user = find_obj_in_resp response, 'User' verify_user resp_user, email @@ -526,7 +545,8 @@ class UserTest < ActiveSupport::TestCase verify_link group_perm, 'permission', 'can_read', resp_user[:uuid], nil # invoke setup again with repo_name - response = User.setup user, openid_prefix, 'foo/testrepo' + response = user.setup(openid_prefix: openid_prefix, + repo_name: 'foo/testrepo') resp_user = find_obj_in_resp response, 'User', nil verify_user resp_user, email assert_equal user.uuid, resp_user[:uuid], 'expected uuid not found' @@ -540,7 +560,9 @@ class UserTest < ActiveSupport::TestCase # invoke setup again with a vm_uuid vm = VirtualMachine.create - response = User.setup user, openid_prefix, 'foo/testrepo', vm.uuid + response = user.setup(openid_prefix: openid_prefix, + repo_name: 'foo/testrepo', + vm_uuid: vm.uuid) resp_user = find_obj_in_resp response, 'User', nil verify_user resp_user, email @@ -621,11 +643,11 @@ class UserTest < ActiveSupport::TestCase assert_equal(expect_username, user.username) # check user setup - verify_link_exists(Rails.configuration.auto_setup_new_users, + verify_link_exists(Rails.configuration.auto_setup_new_users || active, groups(:all_users).uuid, user.uuid, "permission", "can_read") # Check for OID login link. - verify_link_exists(Rails.configuration.auto_setup_new_users, + verify_link_exists(Rails.configuration.auto_setup_new_users || active, user.uuid, user.email, "permission", "can_login") # Check for repository. if named_repo = (prior_repo or @@ -699,4 +721,83 @@ class UserTest < ActiveSupport::TestCase end end + [ + [:active, 'zzzzz-borkd-abcde12345abcde'], + [:active, 'zzzzz-j7d0g-abcde12345abcde'], + [:active, 'zzzzz-tpzed-borkd'], + [:system_user, 'zzzzz-tpzed-abcde12345abcde'], + [:anonymous, 'zzzzz-tpzed-abcde12345abcde'], + ].each do |fixture, new_uuid| + test "disallow update_uuid #{fixture} -> #{new_uuid}" do + u = users(fixture) + orig_uuid = u.uuid + act_as_system_user do + assert_raises do + u.update_uuid(new_uuid: new_uuid) + end + end + # "Successfully aborted orig->new" outcome looks the same as + # "successfully updated new->orig". + assert_update_success(old_uuid: new_uuid, + new_uuid: orig_uuid, + expect_owned_objects: fixture == :active) + end + end + + [:active, :spectator, :admin].each do |target| + test "update_uuid on #{target} as non-admin user" do + act_as_user users(:active) do + assert_raises(ArvadosModel::PermissionDeniedError) do + users(target).update_uuid(new_uuid: 'zzzzz-tpzed-abcde12345abcde') + end + end + end + end + + test "update_uuid to existing uuid" do + u = users(:active) + orig_uuid = u.uuid + new_uuid = users(:admin).uuid + act_as_system_user do + assert_raises do + u.update_uuid(new_uuid: new_uuid) + end + end + u.reload + assert_equal u.uuid, orig_uuid + assert_not_empty Collection.where(owner_uuid: orig_uuid) + assert_not_empty Group.where(owner_uuid: orig_uuid) + end + + [ + [:active, 'zbbbb-tpzed-abcde12345abcde'], + [:active, 'zzzzz-tpzed-abcde12345abcde'], + [:admin, 'zbbbb-tpzed-abcde12345abcde'], + [:admin, 'zzzzz-tpzed-abcde12345abcde'], + ].each do |fixture, new_uuid| + test "update_uuid #{fixture} to unused uuid #{new_uuid}" do + u = users(fixture) + orig_uuid = u.uuid + act_as_system_user do + u.update_uuid(new_uuid: new_uuid) + end + assert_update_success(old_uuid: orig_uuid, + new_uuid: new_uuid, + expect_owned_objects: fixture == :active) + end + end + + def assert_update_success(old_uuid:, new_uuid:, expect_owned_objects: true) + [[User, :uuid], + [Link, :head_uuid], + [Link, :tail_uuid], + [Group, :owner_uuid], + [Collection, :owner_uuid], + ].each do |klass, attr| + assert_empty klass.where(attr => old_uuid) + if klass == User || expect_owned_objects + assert_not_empty klass.where(attr => new_uuid) + end + end + end end