1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe ProjectAccessTokenEntity do
let_it_be(:project) { create(:project) }
let_it_be(:bot) { create(:user, :project_bot) }
let_it_be(:token) { create(:personal_access_token, user: bot) }
subject(:json) { described_class.new(token, project: project).as_json }
context 'when bot is a member of the project' do
before do
project.add_developer(bot)
end
it 'has the correct attributes' do
expected_revoke_path = Gitlab::Routing.url_helpers
.revoke_namespace_project_settings_access_token_path(
{ id: token,
namespace_id: project.namespace.full_path,
project_id: project.path })
expect(json).to(
include(
id: token.id,
name: token.name,
scopes: token.scopes,
user_id: token.user_id,
revoke_path: expected_revoke_path,
role: 'Developer'
))
expect(json).not_to include(:token)
end
end
context 'when bot is unrelated to the project' do
let_it_be(:project) { create(:project) }
it 'has the correct attributes' do
expected_revoke_path = Gitlab::Routing.url_helpers
.revoke_namespace_project_settings_access_token_path(
{ id: token,
namespace_id: project.namespace.full_path,
project_id: project.path })
expect(json).to(
include(
id: token.id,
name: token.name,
scopes: token.scopes,
user_id: token.user_id,
revoke_path: expected_revoke_path,
role: nil
))
expect(json).not_to include(:token)
end
end
end
|