X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/67a54670123669370bb4e664c7e40c71f7539b5f..ee21f45e958de5ef39970981ead6416e3790cd1a:/services/api/test/functional/arvados/v1/users_controller_test.rb?ds=sidebyside 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 c364613060..daf19a9ab0 100644 --- a/services/api/test/functional/arvados/v1/users_controller_test.rb +++ b/services/api/test/functional/arvados/v1/users_controller_test.rb @@ -73,10 +73,28 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase } } assert_response :success - response_items = JSON.parse(@response.body)['items'] - created = response_items['user'] + 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_not_nil created['email'], 'expected non-nil email' + assert_nil created['identity_url'], 'expected no identity_url' + # invoke setup again with the same data + post :setup, { + repo_name: repo_name, + openid_prefix: 'https://www.google.com/accounts/o8/id', + user: { + uuid: "this_is_agreeable", + first_name: "in_create_test_first_name", + last_name: "test_last_name", + email: "test@abc.com" + } + } + + 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'] @@ -84,19 +102,19 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase assert_nil created['identity_url'], 'expected no identity_url' # since no such vm exists, expect only three new links: - # oid_login_perm, repo link and link add user to 'All users' group + # arvados#user, repo link and link add user to 'All users' group verify_num_links @all_links_at_start, 3 - verify_link response_items, 'oid_login_perm', true, 'permission', 'can_login', + verify_link response_items, 'arvados#user', true, 'permission', 'can_login', created['uuid'], created['email'], 'arvados#user', false, 'User' - verify_link response_items, 'repo_perm', true, 'permission', 'can_write', + verify_link response_items, 'arvados#repository', true, 'permission', 'can_write', repo_name, created['uuid'], 'arvados#repository', true, 'Repository' - verify_link response_items, 'group_perm', true, 'permission', 'can_read', + verify_link response_items, 'arvados#group', true, 'permission', 'can_read', 'All users', created['uuid'], 'arvados#group', true, 'Group' - verify_link response_items, 'vm_login_perm', false, 'permission', 'can_login', + verify_link response_items, 'arvados#virtualMachine', false, 'permission', 'can_login', nil, created['uuid'], 'arvados#virtualMachine', false, 'VirtualMachine' end @@ -106,8 +124,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase post :setup, { uuid: 'bogus_uuid', repo_name: 'test_repo', - vm_uuid: @vm_uuid, - openid_prefix: 'https://www.google.com/accounts/o8/id' + vm_uuid: @vm_uuid } response_body = JSON.parse(@response.body) response_errors = response_body['errors'] @@ -127,7 +144,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase response_body = JSON.parse(@response.body) response_errors = response_body['errors'] assert_not_nil response_errors, 'Expected error in response' - assert (response_errors.first.include? 'RuntimeError: No email found'), + assert (response_errors.first.include? 'ArgumentError: Require user email'), 'Expected RuntimeError' end @@ -135,7 +152,6 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase authorize_with :admin post :setup, { - #uuid: 'not_an_existing_uuid_and_not_email_format', repo_name: 'test_repo', vm_uuid: @vm_uuid, openid_prefix: 'https://www.google.com/accounts/o8/id' @@ -143,7 +159,7 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase response_body = JSON.parse(@response.body) response_errors = response_body['errors'] assert_not_nil response_errors, 'Expected error in response' - assert (response_errors.first.include? 'Required uuid or email'), + assert (response_errors.first.include? 'Required uuid or user'), 'Expected ArgumentError' end @@ -159,8 +175,8 @@ class Arvados::V1::UsersControllerTest < ActionController::TestCase response_body = JSON.parse(@response.body) response_errors = response_body['errors'] assert_not_nil response_errors, 'Expected error in response' - assert (response_errors.first.include? '