summaryrefslogtreecommitdiff
path: root/spec/finders/merge_requests/by_approvals_finder_spec.rb
blob: 0e1856879f156639ca84a81634d2ba68d1a55fa7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe MergeRequests::ByApprovalsFinder do
  let_it_be(:first_user) { create(:user) }
  let_it_be(:second_user) { create(:user) }
  let(:third_user) { create(:user) }

  let_it_be(:merge_request_without_approvals) { create(:merge_request) }
  let_it_be(:merge_request_with_first_user_approval) do
    create(:merge_request).tap do |mr|
      create(:approval, merge_request: mr, user: first_user)
    end
  end
  let_it_be(:merge_request_with_both_approvals) do
    create(:merge_request).tap do |mr|
      create(:approval, merge_request: mr, user: first_user)
      create(:approval, merge_request: mr, user: second_user)
    end
  end

  def merge_requests(ids: nil, names: [])
    described_class.new(names, ids).execute(MergeRequest.all)
  end

  context 'filter by no approvals' do
    it 'returns merge requests without approvals' do
      expected_result = [merge_request_without_approvals]

      expect(merge_requests(ids: 'None')).to match_array(expected_result)
      expect(merge_requests(names: ['None'])).to match_array(expected_result)
    end
  end

  context 'filter by any approvals' do
    it 'returns merge requests approved by at least one user' do
      expected_result = [merge_request_with_first_user_approval, merge_request_with_both_approvals]

      expect(merge_requests(ids: 'Any')).to match_array(expected_result)
      expect(merge_requests(names: ['Any'])).to match_array(expected_result)
    end
  end

  context 'filter by specific user approval' do
    it 'returns merge requests approved by specific user' do
      expected_result = [merge_request_with_first_user_approval, merge_request_with_both_approvals]

      expect(merge_requests(ids: [first_user.id])).to match_array(expected_result)
      expect(merge_requests(names: [first_user.username])).to match_array(expected_result)
    end
  end

  context 'filter by multiple user approval' do
    it 'returns merge requests approved by both users' do
      expected_result = [merge_request_with_both_approvals]

      expect(merge_requests(ids: [first_user.id, second_user.id])).to match_array(expected_result)
      expect(merge_requests(names: [first_user.username, second_user.username])).to match_array(expected_result)
    end

    context 'limiting max conditional elements' do
      it 'returns merge requests approved by both users, considering limit of 2 being defined' do
        stub_const('MergeRequests::ByApprovalsFinder::MAX_FILTER_ELEMENTS', 2)

        expected_result = [merge_request_with_both_approvals]

        expect(merge_requests(ids: [first_user.id, second_user.id, third_user.id])).to match_array(expected_result)
        expect(merge_requests(names: [first_user.username, second_user.username, third_user.username])).to match_array(expected_result)
      end
    end
  end

  context 'with empty params' do
    it 'returns all merge requests' do
      expected_result = [merge_request_without_approvals, merge_request_with_first_user_approval, merge_request_with_both_approvals]

      expect(merge_requests(ids: [])).to match_array(expected_result)
      expect(merge_requests(names: [])).to match_array(expected_result)
    end
  end
end