X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/1a7c5c627ca9cbbbc13e1c9710bbd6268c59b22a..ef1d036dce19a8a45605bbaa52bc2a9e5d6bd36a:/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 c00164c0a3..12384cba92 100644 --- a/services/api/test/unit/user_test.rb +++ b/services/api/test/unit/user_test.rb @@ -447,30 +447,40 @@ class UserTest < ActiveSupport::TestCase assert_not_allowed { User.new.save } end - test "setup new user" do - set_user_from_auth :admin + [true, false].each do |visible| + test "setup new user with ActivatedUsersAreVisibleToOthers=#{visible}" do + Rails.configuration.Users.ActivatedUsersAreVisibleToOthers = visible + set_user_from_auth :admin - email = 'foo@example.com' + email = 'foo@example.com' - user = User.create ({uuid: 'zzzzz-tpzed-abcdefghijklmno', email: email}) + user = User.create ({uuid: 'zzzzz-tpzed-abcdefghijklmno', email: email}) - vm = VirtualMachine.create + vm = VirtualMachine.create - response = user.setup(repo_name: 'foo/testrepo', - vm_uuid: vm.uuid) + response = user.setup(repo_name: 'foo/testrepo', + vm_uuid: vm.uuid) - resp_user = find_obj_in_resp response, 'User' - verify_user resp_user, email + resp_user = find_obj_in_resp response, 'User' + verify_user resp_user, email - group_perm = find_obj_in_resp response, 'Link', 'arvados#group' - verify_link group_perm, 'permission', 'can_read', resp_user[:uuid], nil + group_perm = find_obj_in_resp response, 'Link', 'arvados#group' + verify_link group_perm, 'permission', 'can_write', resp_user[:uuid], groups(:all_users).uuid - repo_perm = find_obj_in_resp response, 'Link', 'arvados#repository' - verify_link repo_perm, 'permission', 'can_manage', resp_user[:uuid], nil + group_perm2 = find_obj_in_resp response, 'Link', 'arvados#user' + if visible + verify_link group_perm2, 'permission', 'can_read', groups(:all_users).uuid, nil + else + assert_nil group_perm2 + end - vm_perm = find_obj_in_resp response, 'Link', 'arvados#virtualMachine' - verify_link vm_perm, 'permission', 'can_login', resp_user[:uuid], vm.uuid - assert_equal("foo", vm_perm.properties["username"]) + repo_perm = find_obj_in_resp response, 'Link', 'arvados#repository' + verify_link repo_perm, 'permission', 'can_manage', resp_user[:uuid], nil + + vm_perm = find_obj_in_resp response, 'Link', 'arvados#virtualMachine' + verify_link vm_perm, 'permission', 'can_login', resp_user[:uuid], vm.uuid + assert_equal("foo", vm_perm.properties["username"]) + end end test "setup new user with junk in database" do @@ -489,7 +499,7 @@ class UserTest < ActiveSupport::TestCase verify_user resp_user, email group_perm = find_obj_in_resp response, 'Link', 'arvados#group' - verify_link group_perm, 'permission', 'can_read', resp_user[:uuid], nil + verify_link group_perm, 'permission', 'can_write', resp_user[:uuid], groups(:all_users).uuid repo_perm = find_obj_in_resp response, 'Link', 'arvados#repository' verify_link repo_perm, 'permission', 'can_manage', resp_user[:uuid], nil @@ -512,7 +522,10 @@ class UserTest < ActiveSupport::TestCase verify_user resp_user, email group_perm = find_obj_in_resp response, 'Link', 'arvados#group' - verify_link group_perm, 'permission', 'can_read', resp_user[:uuid], nil + verify_link group_perm, 'permission', 'can_write', resp_user[:uuid], groups(:all_users).uuid + + group_perm2 = find_obj_in_resp response, 'Link', 'arvados#user' + verify_link group_perm2, 'permission', 'can_read', groups(:all_users).uuid, nil # invoke setup again with repo_name response = user.setup(repo_name: 'foo/testrepo') @@ -521,7 +534,7 @@ class UserTest < ActiveSupport::TestCase assert_equal user.uuid, resp_user[:uuid], 'expected uuid not found' group_perm = find_obj_in_resp response, 'Link', 'arvados#group' - verify_link group_perm, 'permission', 'can_read', resp_user[:uuid], nil + verify_link group_perm, 'permission', 'can_write', resp_user[:uuid], groups(:all_users).uuid repo_perm = find_obj_in_resp response, 'Link', 'arvados#repository' verify_link repo_perm, 'permission', 'can_manage', resp_user[:uuid], nil @@ -537,7 +550,7 @@ class UserTest < ActiveSupport::TestCase assert_equal user.uuid, resp_user[:uuid], 'expected uuid not found' group_perm = find_obj_in_resp response, 'Link', 'arvados#group' - verify_link group_perm, 'permission', 'can_read', resp_user[:uuid], nil + verify_link group_perm, 'permission', 'can_write', resp_user[:uuid], groups(:all_users).uuid repo_perm = find_obj_in_resp response, 'Link', 'arvados#repository' verify_link repo_perm, 'permission', 'can_manage', resp_user[:uuid], nil @@ -560,7 +573,7 @@ class UserTest < ActiveSupport::TestCase break end else # looking for a link - if ArvadosModel::resource_class_for_uuid(x['head_uuid']).kind == head_kind + if ArvadosModel::resource_class_for_uuid(x['head_uuid']).andand.kind == head_kind return_obj = x break end @@ -612,7 +625,7 @@ class UserTest < ActiveSupport::TestCase # check user setup verify_link_exists(Rails.configuration.Users.AutoSetupNewUsers || active, groups(:all_users).uuid, user.uuid, - "permission", "can_read") + "permission", "can_write") # Check for repository. if named_repo = (prior_repo or @@ -784,4 +797,12 @@ class UserTest < ActiveSupport::TestCase assert user.save end + test "empty identity_url saves as null" do + set_user_from_auth :admin + user = users(:active) + assert user.update_attributes(identity_url: '') + user.reload + assert_nil user.identity_url + end + end