2019-07-07 11:18:12 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-09-13 17:45:13 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2023-04-23 21:23:45 +05:30
|
|
|
RSpec.describe Discussion, feature_category: :team_planning do
|
2016-09-13 17:45:13 +05:30
|
|
|
subject { described_class.new([first_note, second_note, third_note]) }
|
|
|
|
|
|
|
|
let(:first_note) { create(:diff_note_on_merge_request) }
|
2017-08-17 22:00:37 +05:30
|
|
|
let(:merge_request) { first_note.noteable }
|
|
|
|
let(:second_note) { create(:diff_note_on_merge_request, in_reply_to: first_note) }
|
2016-09-13 17:45:13 +05:30
|
|
|
let(:third_note) { create(:diff_note_on_merge_request) }
|
|
|
|
|
2019-09-30 21:07:59 +05:30
|
|
|
describe '.lazy_find' do
|
|
|
|
let!(:note1) { create(:discussion_note_on_merge_request).to_discussion }
|
|
|
|
let!(:note2) { create(:discussion_note_on_merge_request, in_reply_to: note1).to_discussion }
|
|
|
|
|
|
|
|
subject { [note1, note2].map { |note| described_class.lazy_find(note.discussion_id) } }
|
|
|
|
|
|
|
|
it 'batches requests' do
|
|
|
|
expect do
|
|
|
|
[described_class.lazy_find(note1.id),
|
|
|
|
described_class.lazy_find(note2.id)].map(&:__sync)
|
|
|
|
end.not_to exceed_query_limit(1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
describe '.build' do
|
|
|
|
it 'returns a discussion of the right type' do
|
|
|
|
discussion = described_class.build([first_note, second_note], merge_request)
|
|
|
|
expect(discussion).to be_a(DiffDiscussion)
|
|
|
|
expect(discussion.notes.count).to be(2)
|
|
|
|
expect(discussion.first_note).to be(first_note)
|
|
|
|
expect(discussion.noteable).to be(merge_request)
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
describe '.build_collection' do
|
|
|
|
it 'returns an array of discussions of the right type' do
|
|
|
|
discussions = described_class.build_collection([first_note, second_note, third_note], merge_request)
|
2022-11-25 23:54:43 +05:30
|
|
|
expect(discussions).to eq(
|
|
|
|
[
|
|
|
|
DiffDiscussion.new([first_note, second_note], merge_request),
|
|
|
|
DiffDiscussion.new([third_note], merge_request)
|
|
|
|
])
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|
|
|
|
end
|
2019-09-04 21:01:54 +05:30
|
|
|
|
|
|
|
describe 'authorization' do
|
|
|
|
it 'delegates to the first note' do
|
|
|
|
policy = DeclarativePolicy.policy_for(instance_double(User, id: 1), subject)
|
|
|
|
|
|
|
|
expect(policy).to be_a(NotePolicy)
|
|
|
|
end
|
|
|
|
end
|
2021-09-30 23:02:18 +05:30
|
|
|
|
|
|
|
describe '#cache_key' do
|
2021-10-27 15:23:28 +05:30
|
|
|
let(:notes_sha) { Digest::SHA1.hexdigest("#{first_note.post_processed_cache_key}:#{second_note.post_processed_cache_key}:#{third_note.post_processed_cache_key}") }
|
2021-09-30 23:02:18 +05:30
|
|
|
|
2021-10-27 15:23:28 +05:30
|
|
|
it 'returns the cache key' do
|
|
|
|
expect(subject.cache_key).to eq("#{described_class::CACHE_VERSION}:#{subject.id}:#{notes_sha}:")
|
2021-09-30 23:02:18 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context 'when discussion is resolved' do
|
|
|
|
before do
|
|
|
|
subject.resolve!(first_note.author)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns the cache key with resolved at' do
|
2021-10-27 15:23:28 +05:30
|
|
|
expect(subject.cache_key).to eq("#{described_class::CACHE_VERSION}:#{subject.id}:#{notes_sha}:#{subject.resolved_at}")
|
2021-09-30 23:02:18 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2023-04-23 21:23:45 +05:30
|
|
|
|
|
|
|
describe '#to_global_id' do
|
|
|
|
context 'with a single DiffNote discussion' do
|
|
|
|
it 'returns GID on Discussion class' do
|
|
|
|
discussion = described_class.build([first_note], merge_request)
|
|
|
|
discussion_id = discussion.id
|
|
|
|
|
|
|
|
expect(discussion.class.name.to_s).to eq("DiffDiscussion")
|
|
|
|
expect(discussion.to_global_id.to_s).to eq("gid://gitlab/Discussion/#{discussion_id}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with multiple DiffNotes discussion' do
|
|
|
|
it 'returns GID on Discussion class' do
|
|
|
|
discussion = described_class.build([first_note, second_note], merge_request)
|
|
|
|
discussion_id = discussion.id
|
|
|
|
|
|
|
|
expect(discussion.class.name.to_s).to eq("DiffDiscussion")
|
|
|
|
expect(discussion.to_global_id.to_s).to eq("gid://gitlab/Discussion/#{discussion_id}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with discussions on issue' do
|
|
|
|
let_it_be(:note_1, refind: true) { create(:note) }
|
|
|
|
let_it_be(:noteable) { note_1.noteable }
|
|
|
|
|
|
|
|
context 'with a single Note' do
|
|
|
|
it 'returns GID on Discussion class' do
|
|
|
|
discussion = described_class.build([note_1], noteable)
|
|
|
|
discussion_id = discussion.id
|
|
|
|
|
|
|
|
expect(discussion.class.name.to_s).to eq("IndividualNoteDiscussion")
|
|
|
|
expect(discussion.to_global_id.to_s).to eq("gid://gitlab/Discussion/#{discussion_id}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with multiple Notes' do
|
|
|
|
let_it_be(:note_1, refind: true) { create(:note, type: 'DiscussionNote') }
|
|
|
|
let_it_be(:note_2, refind: true) { create(:note, in_reply_to: note_1) }
|
|
|
|
|
|
|
|
it 'returns GID on Discussion class' do
|
|
|
|
discussion = described_class.build([note_1, note_2], noteable)
|
|
|
|
discussion_id = discussion.id
|
|
|
|
|
|
|
|
expect(discussion.class.name.to_s).to eq("Discussion")
|
|
|
|
expect(discussion.to_global_id.to_s).to eq("gid://gitlab/Discussion/#{discussion_id}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with system notes' do
|
|
|
|
let_it_be(:system_note, refind: true) { create(:note, system: true) }
|
|
|
|
let_it_be(:noteable) { system_note.noteable }
|
|
|
|
|
|
|
|
it 'returns GID on Discussion class' do
|
|
|
|
discussion = described_class.build([system_note], noteable)
|
|
|
|
discussion_id = discussion.id
|
|
|
|
|
|
|
|
expect(discussion.class.name.to_s).to eq("IndividualNoteDiscussion")
|
|
|
|
expect(discussion.to_global_id.to_s).to eq("gid://gitlab/Discussion/#{discussion_id}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|