diff options
| author | GitLab Bot <gitlab-bot@gitlab.com> | 2023-03-17 18:07:58 +0000 |
|---|---|---|
| committer | GitLab Bot <gitlab-bot@gitlab.com> | 2023-03-17 18:07:58 +0000 |
| commit | c18d1c1bd2d0339ddcff4d320ee306fa03692986 (patch) | |
| tree | 69ba5a0895df814d4bc86508634dd843413d79e5 /spec/graphql/mutations | |
| parent | 46d07ca5c2b729d6396723290a875a317b2845ee (diff) | |
| download | gitlab-ce-c18d1c1bd2d0339ddcff4d320ee306fa03692986.tar.gz | |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/graphql/mutations')
| -rw-r--r-- | spec/graphql/mutations/achievements/revoke_spec.rb | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/spec/graphql/mutations/achievements/revoke_spec.rb b/spec/graphql/mutations/achievements/revoke_spec.rb new file mode 100644 index 00000000000..0c221b492af --- /dev/null +++ b/spec/graphql/mutations/achievements/revoke_spec.rb @@ -0,0 +1,57 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Mutations::Achievements::Revoke, feature_category: :user_profile do + include GraphqlHelpers + + let_it_be(:developer) { create(:user) } + let_it_be(:maintainer) { create(:user) } + let_it_be(:recipient) { create(:user) } + let_it_be(:group) { create(:group) } + let_it_be(:achievement) { create(:achievement, namespace: group) } + let_it_be(:user_achievement) { create(:user_achievement, achievement: achievement) } + + describe '#resolve' do + subject(:resolve_mutation) do + described_class.new(object: nil, context: { current_user: current_user }, field: nil).resolve( + user_achievement_id: user_achievement&.to_global_id + ) + end + + before_all do + group.add_developer(developer) + group.add_maintainer(maintainer) + end + + context 'when the user does not have permission' do + let(:current_user) { developer } + + it 'raises an error' do + expect { resolve_mutation }.to raise_error(Gitlab::Graphql::Errors::ResourceNotAvailable) + .with_message(Gitlab::Graphql::Authorize::AuthorizeResource::RESOURCE_ACCESS_ERROR) + end + end + + context 'when the user has permission' do + let(:current_user) { maintainer } + + context 'when the params are invalid' do + let(:user_achievement) { nil } + + it 'returns the validation error' do + expect { resolve_mutation }.to raise_error { Gitlab::Graphql::Errors::ArgumentError } + end + end + + it 'revokes user_achievement' do + response = resolve_mutation[:user_achievement] + + expect(response.revoked_at).not_to be_nil + expect(response.revoked_by_user_id).to be(current_user.id) + end + end + end + + specify { expect(described_class).to require_graphql_authorizations(:award_achievement) } +end |
