Commit 0f45abf2 authored by Serena Fang's avatar Serena Fang

Expose token value

Use Entity PersonalAccessTokenWithToken
to expose token value on creation,
add specs for create and get api endpoints
parent 83af89ed
...@@ -78,7 +78,8 @@ curl --request POST --header "PRIVATE-TOKEN: <your_access_token>" \ ...@@ -78,7 +78,8 @@ curl --request POST --header "PRIVATE-TOKEN: <your_access_token>" \
"created_at" : "2021-01-21T19:35:37.921Z", "created_at" : "2021-01-21T19:35:37.921Z",
"user_id" : 166, "user_id" : 166,
"id" : 58, "id" : 58,
"expires_at" : "2021-01-31" "expires_at" : "2021-01-31",
"token" : "D4y...Wzr"
} }
``` ```
......
...@@ -69,7 +69,7 @@ module API ...@@ -69,7 +69,7 @@ module API
).execute ).execute
if token_response.success? if token_response.success?
present token_response.payload[:access_token], with: Entities::PersonalAccessToken present token_response.payload[:access_token], with: Entities::PersonalAccessTokenWithToken
else else
bad_request!(token_response.message) bad_request!(token_response.message)
end end
......
...@@ -30,6 +30,18 @@ RSpec.describe API::ResourceAccessTokens do ...@@ -30,6 +30,18 @@ RSpec.describe API::ResourceAccessTokens do
expect(token_ids).to match_array(access_tokens.pluck(:id)) expect(token_ids).to match_array(access_tokens.pluck(:id))
end end
it "exposes the correct token information", :aggregate_failures do
get_tokens
token = access_tokens.last
api_get_token = json_response.last
expect(api_get_token["name"]).to eq(token.name)
expect(api_get_token["scopes"]).to eq(token.scopes)
expect(api_get_token["expires_at"]).to eq(token.expires_at.to_date.iso8601)
expect(api_get_token["token"]).to be_nil
end
context "when using a project access token to GET other project access tokens" do context "when using a project access token to GET other project access tokens" do
let_it_be(:token) { access_tokens.first } let_it_be(:token) { access_tokens.first }
...@@ -203,6 +215,7 @@ RSpec.describe API::ResourceAccessTokens do ...@@ -203,6 +215,7 @@ RSpec.describe API::ResourceAccessTokens do
expect(json_response["name"]).to eq("test") expect(json_response["name"]).to eq("test")
expect(json_response["scopes"]).to eq(["api"]) expect(json_response["scopes"]).to eq(["api"])
expect(json_response["expires_at"]).to eq(expires_at.to_date.iso8601) expect(json_response["expires_at"]).to eq(expires_at.to_date.iso8601)
expect(json_response["token"]).not_to be_nil
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment