X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/848940a94d956c26297164cd6c7a51785db82726..8f39c027e4895a8d872093c3dd16aa51b26a3731:/services/api/test/integration/api_client_authorizations_api_test.rb diff --git a/services/api/test/integration/api_client_authorizations_api_test.rb b/services/api/test/integration/api_client_authorizations_api_test.rb index 5c3c0ddfea..78841fe762 100644 --- a/services/api/test/integration/api_client_authorizations_api_test.rb +++ b/services/api/test/integration/api_client_authorizations_api_test.rb @@ -8,4 +8,40 @@ class ApiClientAuthorizationsApiTest < ActionDispatch::IntegrationTest assert_response :success end + test "create token for different user" do + post "/arvados/v1/api_client_authorizations", { + :format => :json, + :api_client_authorization => { + :owner_uuid => users(:spectator).uuid + } + }, {'HTTP_AUTHORIZATION' => "OAuth2 #{api_client_authorizations(:admin_trustedclient).api_token}"} + assert_response :success + + get "/arvados/v1/users/current", { + :format => :json + }, {'HTTP_AUTHORIZATION' => "OAuth2 #{json_response['api_token']}"} + @json_response = nil + assert_equal users(:spectator).uuid, json_response['uuid'] + end + + test "refuse to create token for different user if not trusted client" do + post "/arvados/v1/api_client_authorizations", { + :format => :json, + :api_client_authorization => { + :owner_uuid => users(:spectator).uuid + } + }, {'HTTP_AUTHORIZATION' => "OAuth2 #{api_client_authorizations(:admin).api_token}"} + assert_response 403 + end + + test "refuse to create token for different user if not admin" do + post "/arvados/v1/api_client_authorizations", { + :format => :json, + :api_client_authorization => { + :owner_uuid => users(:spectator).uuid + } + }, {'HTTP_AUTHORIZATION' => "OAuth2 #{api_client_authorizations(:active_trustedclient).api_token}"} + assert_response 403 + end + end