X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b0a3771f2110b691882226c559eab736ab9aa34d..0561bd0c3c07257fd58ded6c7cfa5feeae97af57:/services/api/test/functional/arvados/v1/users_controller_test.rb diff --git a/services/api/test/functional/arvados/v1/users_controller_test.rb b/services/api/test/functional/arvados/v1/users_controller_test.rb index 0b5ff722df..b75479ff8d 100644 --- a/services/api/test/functional/arvados/v1/users_controller_test.rb +++ b/services/api/test/functional/arvados/v1/users_controller_test.rb @@ -1,3 +1,7 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + require 'test_helper' require 'helpers/users_test_helper' @@ -6,8 +10,9 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase include UsersTestHelper setup do - @all_links_at_start = Link.all + @initial_link_count = Link.count @vm_uuid = virtual_machines(:testvm).uuid + ActionMailer::Base.deliveries = [] end test "activate a user after signing UA" do @@ -83,7 +88,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase test "create user with user, vm and repo as input" do authorize_with :admin - repo_name = 'test_repo' + repo_name = 'usertestrepo' post :setup, { repo_name: repo_name, @@ -107,13 +112,13 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_nil created['identity_url'], 'expected no identity_url' # arvados#user, repo link and link add user to 'All users' group - verify_num_links @all_links_at_start, 4 + verify_links_added 4 verify_link response_items, 'arvados#user', true, 'permission', 'can_login', created['uuid'], created['email'], 'arvados#user', false, 'User' verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage', - repo_name, created['uuid'], 'arvados#repository', true, 'Repository' + "foo/#{repo_name}", created['uuid'], 'arvados#repository', true, 'Repository' verify_link response_items, 'arvados#group', true, 'permission', 'can_read', 'All users', created['uuid'], 'arvados#group', true, 'Group' @@ -129,7 +134,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase post :setup, { uuid: 'bogus_uuid', - repo_name: 'test_repo', + repo_name: 'usertestrepo', vm_uuid: @vm_uuid } response_body = JSON.parse(@response.body) @@ -143,7 +148,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase post :setup, { user: {uuid: 'bogus_uuid'}, - repo_name: 'test_repo', + repo_name: 'usertestrepo', vm_uuid: @vm_uuid, openid_prefix: 'https://www.google.com/accounts/o8/id' } @@ -158,7 +163,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase authorize_with :admin post :setup, { - repo_name: 'test_repo', + repo_name: 'usertestrepo', vm_uuid: @vm_uuid, openid_prefix: 'https://www.google.com/accounts/o8/id' } @@ -174,7 +179,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase post :setup, { user: {}, - repo_name: 'test_repo', + repo_name: 'usertestrepo', vm_uuid: @vm_uuid, openid_prefix: 'https://www.google.com/accounts/o8/id' } @@ -191,7 +196,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase post :setup, { uuid: users(:inactive).uuid, - repo_name: 'test_repo', + repo_name: 'usertestrepo', vm_uuid: @vm_uuid } @@ -207,32 +212,12 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase # expect repo and vm links verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage', - 'test_repo', resp_obj['uuid'], 'arvados#repository', true, 'Repository' + 'inactiveuser/usertestrepo', resp_obj['uuid'], 'arvados#repository', true, 'Repository' verify_link response_items, 'arvados#virtualMachine', true, 'permission', 'can_login', @vm_uuid, resp_obj['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine' end - test "invoke setup with existing uuid in user, verify response" do - authorize_with :admin - inactive_user = users(:inactive) - - post :setup, { - user: {uuid: inactive_user['uuid']}, - openid_prefix: 'https://www.google.com/accounts/o8/id' - } - - assert_response :success - - response_items = JSON.parse(@response.body)['items'] - resp_obj = find_obj_in_resp response_items, 'User', nil - - assert_not_nil resp_obj['uuid'], 'expected uuid for the new user' - assert_equal inactive_user['uuid'], resp_obj['uuid'] - assert_equal inactive_user['email'], resp_obj['email'], - 'expecting inactive user email' - end - test "invoke setup with existing uuid but different email, expect original email" do authorize_with :admin inactive_user = users(:inactive) @@ -257,7 +242,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase authorize_with :admin post :setup, { - repo_name: 'test_repo', + repo_name: 'usertestrepo', user: {email: 'foo@example.com'}, openid_prefix: 'https://www.google.com/accounts/o8/id' } @@ -269,14 +254,14 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_equal response_object['email'], 'foo@example.com', 'expected given email' # four extra links; system_group, login, group and repo perms - verify_num_links @all_links_at_start, 4 + verify_links_added 4 end test "setup user with fake vm and expect error" do authorize_with :admin post :setup, { - repo_name: 'test_repo', + repo_name: 'usertestrepo', vm_uuid: 'no_such_vm', user: {email: 'foo@example.com'}, openid_prefix: 'https://www.google.com/accounts/o8/id' @@ -293,7 +278,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase authorize_with :admin post :setup, { - repo_name: 'test_repo', + repo_name: 'usertestrepo', openid_prefix: 'https://www.google.com/accounts/o8/id', vm_uuid: @vm_uuid, user: {email: 'foo@example.com'} @@ -306,7 +291,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_equal response_object['email'], 'foo@example.com', 'expected given email' # five extra links; system_group, login, group, vm, repo - verify_num_links @all_links_at_start, 5 + verify_links_added 5 end test "setup user with valid email, no vm and no repo as input" do @@ -324,7 +309,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_equal response_object['email'], 'foo@example.com', 'expected given email' # three extra links; system_group, login, and group - verify_num_links @all_links_at_start, 3 + verify_links_added 3 verify_link response_items, 'arvados#user', true, 'permission', 'can_login', response_object['uuid'], response_object['email'], 'arvados#user', false, 'User' @@ -333,7 +318,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase 'All users', response_object['uuid'], 'arvados#group', true, 'Group' verify_link response_items, 'arvados#repository', false, 'permission', 'can_manage', - 'test_repo', response_object['uuid'], 'arvados#repository', true, 'Repository' + 'foo/usertestrepo', response_object['uuid'], 'arvados#repository', true, 'Repository' verify_link response_items, 'arvados#virtualMachine', false, 'permission', 'can_login', nil, response_object['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine' @@ -344,7 +329,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase post :setup, { openid_prefix: 'https://www.google.com/accounts/o8/id', - repo_name: 'test_repo', + repo_name: 'usertestrepo', vm_uuid: @vm_uuid, user: { first_name: 'test_first_name', @@ -361,7 +346,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase 'expecting first name' # five extra links; system_group, login, group, repo and vm - verify_num_links @all_links_at_start, 5 + verify_links_added 5 end test "setup user with an existing user email and check different object is created" do @@ -370,7 +355,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase post :setup, { openid_prefix: 'https://www.google.com/accounts/o8/id', - repo_name: 'test_repo', + repo_name: 'usertestrepo', user: { email: inactive_user['email'] } @@ -384,14 +369,14 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase 'expected different uuid after create operation' assert_equal inactive_user['email'], response_object['email'], 'expected given email' # system_group, openid, group, and repo. No vm link. - verify_num_links @all_links_at_start, 4 + verify_links_added 4 end test "setup user with openid prefix" do authorize_with :admin post :setup, { - repo_name: 'test_repo', + repo_name: 'usertestrepo', openid_prefix: 'http://www.example.com/account', user: { first_name: "in_create_test_first_name", @@ -412,13 +397,13 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase # verify links # four new links: system_group, arvados#user, repo, and 'All users' group. - verify_num_links @all_links_at_start, 4 + verify_links_added 4 verify_link response_items, 'arvados#user', true, 'permission', 'can_login', created['uuid'], created['email'], 'arvados#user', false, 'User' verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage', - 'test_repo', created['uuid'], 'arvados#repository', true, 'Repository' + 'foo/usertestrepo', created['uuid'], 'arvados#repository', true, 'Repository' verify_link response_items, 'arvados#group', true, 'permission', 'can_read', 'All users', created['uuid'], 'arvados#group', true, 'Group' @@ -431,7 +416,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase authorize_with :admin post :setup, { - repo_name: 'test_repo', + repo_name: 'usertestrepo', user: { first_name: "in_create_test_first_name", last_name: "test_last_name", @@ -456,7 +441,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase email: "foo@example.com" }, vm_uuid: @vm_uuid, - repo_name: 'test_repo', + repo_name: 'usertestrepo', openid_prefix: 'https://www.google.com/accounts/o8/id' } @@ -472,13 +457,13 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase # five new links: system_group, arvados#user, repo, vm and 'All # users' group link - verify_num_links @all_links_at_start, 5 + verify_links_added 5 verify_link response_items, 'arvados#user', true, 'permission', 'can_login', created['uuid'], created['email'], 'arvados#user', false, 'User' verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage', - 'test_repo', created['uuid'], 'arvados#repository', true, 'Repository' + 'foo/usertestrepo', created['uuid'], 'arvados#repository', true, 'Repository' verify_link response_items, 'arvados#group', true, 'permission', 'can_read', 'All users', created['uuid'], 'arvados#group', true, 'Group' @@ -522,7 +507,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase # invoke setup with a repository post :setup, { - repo_name: 'new_repo', + repo_name: 'usertestrepo', uuid: active_user['uuid'] } @@ -538,7 +523,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase 'All users', created['uuid'], 'arvados#group', true, 'Group' verify_link response_items, 'arvados#repository', true, 'permission', 'can_manage', - 'new_repo', created['uuid'], 'arvados#repository', true, 'Repository' + 'active/usertestrepo', created['uuid'], 'arvados#repository', true, 'Repository' verify_link response_items, 'arvados#virtualMachine', false, 'permission', 'can_login', nil, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine' @@ -547,6 +532,11 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase test "setup active user with vm and no repo" do authorize_with :admin active_user = users(:active) + repos_query = Repository.where(owner_uuid: active_user.uuid) + repo_link_query = Link.where(tail_uuid: active_user.uuid, + link_class: "permission", name: "can_manage") + repos_count = repos_query.count + repo_link_count = repo_link_query.count # invoke setup with a repository post :setup, { @@ -566,8 +556,8 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase verify_link response_items, 'arvados#group', true, 'permission', 'can_read', 'All users', created['uuid'], 'arvados#group', true, 'Group' - verify_link response_items, 'arvados#repository', false, 'permission', 'can_manage', - 'new_repo', created['uuid'], 'arvados#repository', true, 'Repository' + assert_equal(repos_count, repos_query.count) + assert_equal(repo_link_count, repo_link_query.count) verify_link response_items, 'arvados#virtualMachine', true, 'permission', 'can_login', @vm_uuid, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine' @@ -579,7 +569,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert active_user['is_active'], 'expected is_active for active user' verify_link_existence active_user['uuid'], active_user['email'], - false, true, false, true, true + false, true, true, true, true authorize_with :admin @@ -598,7 +588,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase active_user = User.find_by_uuid(users(:active).uuid) readable_groups = active_user.groups_i_can(:read) - all_users_group = Group.all.collect(&:uuid).select { |g| g.match /-f+$/ } + all_users_group = Group.all.collect(&:uuid).select { |g| g.match(/-f+$/) } refute_includes(readable_groups, all_users_group, "active user can read All Users group after being deactivated") assert_equal(false, active_user.is_invited, @@ -648,13 +638,28 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_equal Rails.configuration.user_notifier_email_from, setup_email.from[0] assert_equal 'foo@example.com', setup_email.to[0] - assert_equal 'Welcome to Curoverse', setup_email.subject - assert (setup_email.body.to_s.include? 'Your Arvados account has been set up'), - 'Expected Your Arvados account has been set up in email body' - assert (setup_email.body.to_s.include? 'foo@example.com'), - 'Expected user email in email body' - assert (setup_email.body.to_s.include? Rails.configuration.workbench_address), - 'Expected workbench url in email body' + assert_equal 'Welcome to Curoverse - shell account enabled', setup_email.subject + assert (setup_email.body.to_s.include? 'Your Arvados shell account has been set up'), + 'Expected Your Arvados shell account has been set up in email body' + assert (setup_email.body.to_s.include? "#{Rails.configuration.workbench_address}users/#{created['uuid']}/virtual_machines"), 'Expected virtual machines url in email body' + end + + test "setup inactive user by changing is_active to true" do + authorize_with :admin + active_user = users(:active) + + # invoke setup with a repository + put :update, { + id: active_user['uuid'], + user: { + is_active: true, + } + } + assert_response :success + assert_equal active_user['uuid'], json_response['uuid'] + updated = User.where(uuid: active_user['uuid']).first + assert_equal(true, updated.is_active) + assert_equal({read: true}, updated.group_permissions[all_users_group_uuid]) end test "non-admin user can get basic information about readable users" do @@ -839,15 +844,13 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase "admin's filtered index did not return inactive user") end - def verify_num_links (original_links, expected_additional_links) - links_now = Link.all - assert_equal expected_additional_links, Link.all.size-original_links.size, - "Expected #{expected_additional_links.inspect} more links" + def verify_links_added more + assert_equal @initial_link_count+more, Link.count, + "Started with #{@initial_link_count} links, expected #{more} more" end def find_obj_in_resp (response_items, object_type, head_kind=nil) return_obj = nil - response_items response_items.each { |x| if !x next