X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/7023263e319cbd93365f7104c866aba4886616da..8048da32800fab790b68f502c52dd00c89b5b690:/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 2a7f686f34..6dc5950dd8 100644 --- a/services/api/test/functional/arvados/v1/users_controller_test.rb +++ b/services/api/test/functional/arvados/v1/users_controller_test.rb @@ -44,6 +44,12 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_equal true, me['is_active'] end + test "respond 401 if given token exists but user record is missing" do + authorize_with :valid_token_deleted_user + get :current, {format: :json} + assert_response 401 + end + test "create new user with user as input" do authorize_with :admin post :create, user: { @@ -67,7 +73,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase repo_name: repo_name, openid_prefix: 'https://www.google.com/accounts/o8/id', user: { - uuid: "this_is_agreeable", + uuid: 'zzzzz-tpzed-abcdefghijklmno', first_name: "in_create_test_first_name", last_name: "test_last_name", email: "foo@example.com" @@ -77,9 +83,10 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase response_items = JSON.parse(@response.body)['items'] created = find_obj_in_resp response_items, 'User', nil + assert_equal 'in_create_test_first_name', created['first_name'] assert_not_nil created['uuid'], 'expected non-null uuid for the new user' - assert_equal 'this_is_agreeable', created['uuid'] + assert_equal 'zzzzz-tpzed-abcdefghijklmno', created['uuid'] assert_not_nil created['email'], 'expected non-nil email' assert_nil created['identity_url'], 'expected no identity_url' @@ -106,7 +113,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase vm_uuid: @vm_uuid, openid_prefix: 'https://www.google.com/accounts/o8/id', user: { - uuid: "this_is_agreeable", + uuid: 'zzzzz-tpzed-abcdefghijklmno', first_name: "in_create_test_first_name", last_name: "test_last_name", email: "foo@example.com" @@ -118,7 +125,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase created = find_obj_in_resp response_items, 'User', nil assert_equal 'in_create_test_first_name', created['first_name'] assert_not_nil created['uuid'], 'expected non-null uuid for the new user' - assert_equal 'this_is_agreeable', created['uuid'] + assert_equal 'zzzzz-tpzed-abcdefghijklmno', created['uuid'] assert_not_nil created['email'], 'expected non-nil email' assert_nil created['identity_url'], 'expected no identity_url' @@ -659,7 +666,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase verify_link response_items, 'arvados#virtualMachine', true, 'permission', 'can_login', @vm_uuid, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine' - verify_link_existence created['uuid'], created['email'], true, true, true, false + verify_link_existence created['uuid'], created['email'], true, true, true, true, false # now unsetup this user post :unsetup, uuid: created['uuid'] @@ -669,7 +676,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_not_nil created2['uuid'], 'expected uuid for the newly created user' assert_equal created['uuid'], created2['uuid'], 'expected uuid not found' - verify_link_existence created['uuid'], created['email'], false, false, false, false + verify_link_existence created['uuid'], created['email'], false, false, false, false, false end test "unsetup active user" do @@ -679,9 +686,10 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase active_user = JSON.parse(@response.body) assert_not_nil active_user['uuid'], 'expected uuid for the active user' assert active_user['is_active'], 'expected is_active for active user' + assert active_user['is_invited'], 'expected is_invited for active user' verify_link_existence active_user['uuid'], active_user['email'], - false, false, false, true + false, false, false, true, true authorize_with :admin @@ -693,9 +701,62 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_not_nil response_user['uuid'], 'expected uuid for the upsetup user' assert_equal active_user['uuid'], response_user['uuid'], 'expected uuid not found' assert !response_user['is_active'], 'expected user to be inactive' + assert !response_user['is_invited'], 'expected user to be uninvited' verify_link_existence response_user['uuid'], response_user['email'], - false, false, false, false + false, false, false, false, false + end + + test "setup user with send notification param false and verify no email" do + authorize_with :admin + + post :setup, { + openid_prefix: 'http://www.example.com/account', + send_notification_email: 'false', + user: { + email: "foo@example.com" + } + } + + assert_response :success + response_items = JSON.parse(@response.body)['items'] + created = find_obj_in_resp response_items, 'User', nil + assert_not_nil created['uuid'], 'expected uuid for the new user' + assert_equal created['email'], 'foo@example.com', 'expected given email' + + setup_email = ActionMailer::Base.deliveries.last + assert_nil setup_email, 'expected no setup email' + end + + test "setup user with send notification param true and verify email" do + authorize_with :admin + + post :setup, { + openid_prefix: 'http://www.example.com/account', + send_notification_email: 'true', + user: { + email: "foo@example.com" + } + } + + assert_response :success + response_items = JSON.parse(@response.body)['items'] + created = find_obj_in_resp response_items, 'User', nil + assert_not_nil created['uuid'], 'expected uuid for the new user' + assert_equal created['email'], 'foo@example.com', 'expected given email' + + setup_email = ActionMailer::Base.deliveries.last + assert_not_nil setup_email, 'Expected email after setup' + + 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' end def verify_num_links (original_links, expected_additional_links) @@ -712,12 +773,12 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase end if object_type == 'User' - if !x['head_kind'] + if ArvadosModel::resource_class_for_uuid(x['uuid']) == User return_obj = x break end else # looking for a link - if x['head_kind'] == head_kind + if x['head_uuid'] and ArvadosModel::resource_class_for_uuid(x['head_uuid']).kind == head_kind return_obj = x break end @@ -743,29 +804,28 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert [] != object, "expected #{class_name} with name #{head_uuid}" head_uuid = object.first[:uuid] end - assert_equal link['link_class'], link_class, + assert_equal link_class, link['link_class'], "did not find expected link_class for #{link_object_name}" - assert_equal link['name'], link_name, + assert_equal link_name, link['name'], "did not find expected link_name for #{link_object_name}" - assert_equal link['tail_uuid'], tail_uuid, + assert_equal tail_uuid, link['tail_uuid'], "did not find expected tail_uuid for #{link_object_name}" - assert_equal link['head_kind'], head_kind, + assert_equal head_kind, link['head_kind'], "did not find expected head_kind for #{link_object_name}" - assert_equal link['head_uuid'], head_uuid, + assert_equal head_uuid, link['head_uuid'], "did not find expected head_uuid for #{link_object_name}" end def verify_link_existence uuid, email, expect_oid_login_perms, - expect_repo_perms, expect_vm_perms, expect_signatures + expect_repo_perms, expect_vm_perms, expect_group_perms, expect_signatures # verify that all links are deleted for the user oid_login_perms = Link.where(tail_uuid: email, - head_kind: 'arvados#user', link_class: 'permission', - name: 'can_login') + name: 'can_login').where("head_uuid like ?", User.uuid_like_pattern) if expect_oid_login_perms assert oid_login_perms.any?, "expected oid_login_perms" else @@ -773,9 +833,8 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase end repo_perms = Link.where(tail_uuid: uuid, - head_kind: 'arvados#repository', link_class: 'permission', - name: 'can_write') + name: 'can_write').where("head_uuid like ?", Repository.uuid_like_pattern) if expect_repo_perms assert repo_perms.any?, "expected repo_perms" else @@ -783,17 +842,28 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase end vm_login_perms = Link.where(tail_uuid: uuid, - head_kind: 'arvados#virtualMachine', link_class: 'permission', - name: 'can_login') + name: 'can_login').where("head_uuid like ?", VirtualMachine.uuid_like_pattern) if expect_vm_perms assert vm_login_perms.any?, "expected vm_login_perms" else assert !vm_login_perms.any?, "expected all vm_login_perms deleted" end + group = Group.where(name: 'All users').select do |g| + g[:uuid].match /-f+$/ + end.first + group_read_perms = Link.where(tail_uuid: uuid, + head_uuid: group[:uuid], + link_class: 'permission', + name: 'can_read') + if expect_group_perms + assert group_read_perms.any?, "expected all users group read perms" + else + assert !group_read_perms.any?, "expected all users group perm deleted" + end + signed_uuids = Link.where(link_class: 'signature', - tail_kind: 'arvados#user', tail_uuid: uuid) if expect_signatures