BigW Consortium Gitlab

merge_requests_helper_spec.rb 2.17 KB
Newer Older
1 2 3
require 'spec_helper'

describe MergeRequestsHelper do
4
  include ActionView::Helpers::UrlHelper
5
  include ProjectForksHelper
6

7
  describe 'ci_build_details_path' do
8
    let(:project) { create(:project) }
9 10
    let(:merge_request) { MergeRequest.new }
    let(:ci_service) { CiService.new }
11
    let(:last_commit) { Ci::Pipeline.new({}) }
12 13 14 15 16 17 18 19 20

    before do
      allow(merge_request).to receive(:source_project).and_return(project)
      allow(merge_request).to receive(:last_commit).and_return(last_commit)
      allow(project).to receive(:ci_service).and_return(ci_service)
      allow(last_commit).to receive(:sha).and_return('12d65c')
    end

    it 'does not include api credentials in a link' do
21 22
      allow(ci_service)
        .to receive(:build_page).and_return("http://secretuser:secretpass@jenkins.example.com:8888/job/test1/scm/bySHA1/12d65c")
23
      expect(helper.ci_build_details_path(merge_request)).not_to match("secret")
24 25 26
    end
  end

Drew Blessing committed
27 28
  describe '#format_mr_branch_names' do
    describe 'within the same project' do
29 30 31 32 33 34
      let(:merge_request) { create(:merge_request) }
      subject { format_mr_branch_names(merge_request) }

      it { is_expected.to eq([merge_request.source_branch, merge_request.target_branch]) }
    end

Drew Blessing committed
35
    describe 'within different projects' do
36
      let(:project) { create(:project) }
37 38
      let(:forked_project) { fork_project(project) }
      let(:merge_request) { create(:merge_request, source_project: forked_project, target_project: project) }
39
      subject { format_mr_branch_names(merge_request) }
40
      let(:source_title) { "#{forked_project.full_path}:#{merge_request.source_branch}" }
41
      let(:target_title) { "#{project.full_path}:#{merge_request.target_branch}" }
42 43 44 45

      it { is_expected.to eq([source_title, target_title]) }
    end
  end
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60

  describe '#tab_link_for' do
    let(:merge_request) { create(:merge_request, :simple) }
    let(:options) { Hash.new }

    subject { tab_link_for(merge_request, :show, options) { 'Discussion' } }

    describe 'supports the :force_link option' do
      let(:options) { { force_link: true } }

      it 'removes the data-toggle attributes' do
        is_expected.not_to match(/data-toggle="tab"/)
      end
    end
  end
61
end