resolve_discussions_spec.rb 4.1 KB
Newer Older
1 2
require 'spec_helper.rb'

3
describe Issues::ResolveDiscussions do
S
Sean McGivern 已提交
4 5
  class DummyService < Issues::BaseService
    include ::Issues::ResolveDiscussions
6

S
Sean McGivern 已提交
7 8 9 10
    def initialize(*args)
      super
      filter_resolve_discussion_params
    end
11 12
  end

13
  let(:project) { create(:project, :repository) }
14 15 16 17 18 19 20
  let(:user) { create(:user) }

  before do
    project.team << [user, :developer]
  end

  describe "for resolving discussions" do
D
Douwe Maan 已提交
21
    let(:discussion) { create(:diff_note_on_merge_request, project: project, note: "Almost done").to_discussion }
22
    let(:merge_request) { discussion.noteable }
23
    let(:other_merge_request) { create(:merge_request, source_project: project, source_branch: "fix") }
24

25
    describe "#merge_request_for_resolving_discussion" do
S
Sean McGivern 已提交
26
      let(:service) { DummyService.new(project, user, merge_request_to_resolve_discussions_of: merge_request.iid) }
27 28

      it "finds the merge request" do
B
Bob Van Landuyt 已提交
29
        expect(service.merge_request_to_resolve_discussions_of).to eq(merge_request)
30 31 32 33 34 35 36 37 38 39
      end

      it "only queries for the merge request once" do
        fake_finder = double
        fake_results = double

        expect(fake_finder).to receive(:execute).and_return(fake_results).exactly(1)
        expect(fake_results).to receive(:find_by).exactly(1)
        expect(MergeRequestsFinder).to receive(:new).and_return(fake_finder).exactly(1)

B
Bob Van Landuyt 已提交
40
        2.times { service.merge_request_to_resolve_discussions_of }
41 42 43
      end
    end

44
    describe "#discussions_to_resolve" do
45
      it "contains a single discussion when matching merge request and discussion are passed" do
S
Sean McGivern 已提交
46
        service = DummyService.new(
47 48
          project,
          user,
49
          discussion_to_resolve: discussion.id,
B
Bob Van Landuyt 已提交
50
          merge_request_to_resolve_discussions_of: merge_request.iid
51
        )
52 53 54
        # We need to compare discussion id's because the Discussion-objects are rebuilt
        # which causes the object-id's not to be different.
        discussion_ids = service.discussions_to_resolve.map(&:id)
55

56
        expect(discussion_ids).to contain_exactly(discussion.id)
57 58 59 60 61 62 63
      end

      it "contains all discussions when only a merge request is passed" do
        second_discussion = Discussion.new([create(:diff_note_on_merge_request,
                                                  noteable: merge_request,
                                                  project: merge_request.target_project,
                                                  line_number: 15)])
S
Sean McGivern 已提交
64
        service = DummyService.new(
65 66
          project,
          user,
B
Bob Van Landuyt 已提交
67
          merge_request_to_resolve_discussions_of: merge_request.iid
68 69 70 71 72 73 74 75
        )
        # We need to compare discussion id's because the Discussion-objects are rebuilt
        # which causes the object-id's not to be different.
        discussion_ids = service.discussions_to_resolve.map(&:id)

        expect(discussion_ids).to contain_exactly(discussion.id, second_discussion.id)
      end

76
      it "contains only unresolved discussions" do
77
        _second_discussion = Discussion.new([create(:diff_note_on_merge_request, :resolved,
78 79
                                                   noteable: merge_request,
                                                   project: merge_request.target_project,
80
                                                   line_number: 15
81
                                                   )])
S
Sean McGivern 已提交
82
        service = DummyService.new(
83 84
          project,
          user,
B
Bob Van Landuyt 已提交
85
          merge_request_to_resolve_discussions_of: merge_request.iid
86 87 88 89 90 91 92 93
        )
        # We need to compare discussion id's because the Discussion-objects are rebuilt
        # which causes the object-id's not to be different.
        discussion_ids = service.discussions_to_resolve.map(&:id)

        expect(discussion_ids).to contain_exactly(discussion.id)
      end

94
      it "is empty when a discussion and another merge request are passed" do
S
Sean McGivern 已提交
95
        service = DummyService.new(
96 97
          project,
          user,
98
          discussion_to_resolve: discussion.id,
B
Bob Van Landuyt 已提交
99
          merge_request_to_resolve_discussions_of: other_merge_request.iid
100 101 102 103 104 105 106
        )

        expect(service.discussions_to_resolve).to be_empty
      end
    end
  end
end