X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/7024cc159936593350aaf7939d700102f6510787..e2a4e065951ea459570ae75dbe2ed4fd4b6d4bd8:/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