diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-29 18:09:48 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-29 18:09:48 +0300 |
commit | f4d51a9f71cf3d4b0874a3e1948fe3c1ea193c4d (patch) | |
tree | 7ae3da76e824c435167dd108721c0124ad2ee484 /spec/graphql/resolvers | |
parent | 2dedd78ef505a0ab0a379c7340a3fcba56ada663 (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/graphql/resolvers')
-rw-r--r-- | spec/graphql/resolvers/merge_requests_count_resolver_spec.rb | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/spec/graphql/resolvers/merge_requests_count_resolver_spec.rb b/spec/graphql/resolvers/merge_requests_count_resolver_spec.rb new file mode 100644 index 00000000000..da177da93a6 --- /dev/null +++ b/spec/graphql/resolvers/merge_requests_count_resolver_spec.rb @@ -0,0 +1,45 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Resolvers::MergeRequestsCountResolver do + include GraphqlHelpers + + describe '#resolve' do + let_it_be(:user) { create(:user) } + let_it_be(:project1) { create(:project, :repository, :public) } + let_it_be(:project2) { create(:project, :repository, repository_access_level: ProjectFeature::PRIVATE) } + let_it_be(:issue) { create(:issue, project: project1) } + let_it_be(:merge_request_closing_issue1) { create(:merge_requests_closing_issues, issue: issue) } + let_it_be(:merge_request_closing_issue2) do + merge_request = create(:merge_request, source_project: project2) + create(:merge_requests_closing_issues, issue: issue, merge_request: merge_request) + end + + specify do + expect(described_class).to have_nullable_graphql_type(GraphQL::Types::Int) + end + + subject { batch_sync { resolve_merge_requests_count(issue) } } + + context "when user can only view an issue's closing merge requests that are public" do + it 'returns the count of the merge requests closing the issue' do + expect(subject).to eq(1) + end + end + + context "when user can view an issue's closing merge requests that are both public and private" do + before do + project2.add_reporter(user) + end + + it 'returns the count of the merge requests closing the issue' do + expect(subject).to eq(2) + end + end + end + + def resolve_merge_requests_count(obj) + resolve(described_class, obj: obj, ctx: { current_user: user }) + end +end |