diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-08-20 18:42:06 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-08-20 18:42:06 +0000 |
commit | 6e4e1050d9dba2b7b2523fdd1768823ab85feef4 (patch) | |
tree | 78be5963ec075d80116a932011d695dd33910b4e /spec/services/personal_access_tokens/revoke_service_spec.rb | |
parent | 1ce776de4ae122aba3f349c02c17cebeaa8ecf07 (diff) | |
download | gitlab-ce-6e4e1050d9dba2b7b2523fdd1768823ab85feef4.tar.gz |
Add latest changes from gitlab-org/gitlab@13-3-stable-ee
Diffstat (limited to 'spec/services/personal_access_tokens/revoke_service_spec.rb')
-rw-r--r-- | spec/services/personal_access_tokens/revoke_service_spec.rb | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/spec/services/personal_access_tokens/revoke_service_spec.rb b/spec/services/personal_access_tokens/revoke_service_spec.rb new file mode 100644 index 00000000000..5afa43cef76 --- /dev/null +++ b/spec/services/personal_access_tokens/revoke_service_spec.rb @@ -0,0 +1,44 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe PersonalAccessTokens::RevokeService do + shared_examples_for 'a successfully revoked token' do + it { expect(subject.success?).to be true } + it { expect(service.token.revoked?).to be true } + end + + shared_examples_for 'an unsuccessfully revoked token' do + it { expect(subject.success?).to be false } + it { expect(service.token.revoked?).to be false } + end + + describe '#execute' do + subject { service.execute } + + let(:service) { described_class.new(current_user, token: token) } + + context 'when current_user is an administrator' do + let_it_be(:current_user) { create(:admin) } + let_it_be(:token) { create(:personal_access_token) } + + it_behaves_like 'a successfully revoked token' + end + + context 'when current_user is not an administrator' do + let_it_be(:current_user) { create(:user) } + + context 'token belongs to a different user' do + let_it_be(:token) { create(:personal_access_token) } + + it_behaves_like 'an unsuccessfully revoked token' + end + + context 'token belongs to current_user' do + let_it_be(:token) { create(:personal_access_token, user: current_user) } + + it_behaves_like 'a successfully revoked token' + end + end + end +end |