Welcome to mirror list, hosted at ThFree Co, Russian Federation.

context_commits_finder_spec.rb « finders « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: c22675bc67d564b759ce6fd0477c681039f2c90d (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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe ContextCommitsFinder do
  describe "#execute" do
    let(:project) { create(:project, :repository) }
    let(:merge_request) { create(:merge_request, source_branch: 'feature', target_branch: 'master') }
    let(:commit) { create(:commit, id: '6d394385cf567f80a8fd85055db1ab4c5295806f') }

    it 'filters commits by valid sha/commit message' do
      params = { search: commit.id }

      commits = described_class.new(project, merge_request, params).execute

      expect(commits.length).to eq(1)
      expect(commits[0].id).to eq(commit.id)
    end

    it 'returns nothing when searched by invalid sha/commit message' do
      params = { search: 'zzz' }

      commits = described_class.new(project, merge_request, params).execute

      expect(commits).to be_empty
    end

    it 'returns commits based in author filter' do
      params = { search: 'test text', author: 'Job van der Voort' }
      commits = described_class.new(project, merge_request, params).execute

      expect(commits.length).to eq(1)
      expect(commits[0].id).to eq('b83d6e391c22777fca1ed3012fce84f633d7fed0')
    end

    it 'returns commits based in before filter' do
      params = { search: 'test text', committed_before: 1474828200 }
      commits = described_class.new(project, merge_request, params).execute

      expect(commits.length).to eq(1)
      expect(commits[0].id).to eq('498214de67004b1da3d820901307bed2a68a8ef6')
    end

    it 'returns commits based in after filter' do
      params = { search: 'test text', committed_after: 1474828200 }
      commits = described_class.new(project, merge_request, params).execute

      expect(commits.length).to eq(1)
      expect(commits[0].id).to eq('b83d6e391c22777fca1ed3012fce84f633d7fed0')
    end
  end
end