debian-mirror-gitlab/spec/graphql/resolvers/user_discussions_count_resolver_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

57 lines
1.9 KiB
Ruby
Raw Normal View History

2021-02-22 17:27:13 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Resolvers::UserDiscussionsCountResolver do
include GraphqlHelpers
describe '#resolve' do
let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project, :public) }
let_it_be(:private_project) { create(:project, :private) }
let_it_be(:issue) { create(:issue, project: project) }
let_it_be(:private_issue) { create(:issue, project: private_project) }
let_it_be(:public_discussions) { create_list(:discussion_note_on_issue, 2, noteable: issue, project: project) }
let_it_be(:system_discussion) { create(:discussion_note_on_issue, system: true, noteable: issue, project: project) }
let_it_be(:private_discussion) { create_list(:discussion_note_on_issue, 3, noteable: private_issue, project: private_project) }
specify do
2021-10-27 15:23:28 +05:30
expect(described_class).to have_nullable_graphql_type(GraphQL::Types::Int)
2021-02-22 17:27:13 +05:30
end
context 'when counting discussions from a public issue' do
subject { batch_sync { resolve_user_discussions_count(issue) } }
it 'returns the number of discussions for the issue' do
expect(subject).to eq(2)
end
end
context 'when a user has permission to view discussions' do
before do
private_project.add_developer(user)
end
subject { batch_sync { resolve_user_discussions_count(private_issue) } }
it 'returns the number of non-system discussions for the issue' do
expect(subject).to eq(3)
end
end
context 'when a user does not have permission to view discussions' do
subject { batch_sync { resolve_user_discussions_count(private_issue) } }
it 'returns no discussions' do
2022-05-07 20:08:51 +05:30
expect_graphql_error_to_be_created(Gitlab::Graphql::Errors::ResourceNotAvailable) do
subject
end
2021-02-22 17:27:13 +05:30
end
end
end
def resolve_user_discussions_count(obj)
resolve(described_class, obj: obj, ctx: { current_user: user })
end
end