103 lines
2.9 KiB
Ruby
103 lines
2.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe MergeRequestsHelper do
|
|
include ActionView::Helpers::UrlHelper
|
|
include ProjectForksHelper
|
|
|
|
describe '#state_name_with_icon' do
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
let(:merge_request) { MergeRequest.new }
|
|
|
|
where(:state, :expected_name, :expected_icon) do
|
|
:merged? | 'Merged' | 'git-merge'
|
|
:closed? | 'Closed' | 'close'
|
|
:opened? | 'Open' | 'issue-open-m'
|
|
end
|
|
|
|
with_them do
|
|
before do
|
|
allow(merge_request).to receive(state).and_return(true)
|
|
end
|
|
|
|
it 'returns name and icon' do
|
|
name, icon = helper.state_name_with_icon(merge_request)
|
|
|
|
expect(name).to eq(expected_name)
|
|
expect(icon).to eq(expected_icon)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#format_mr_branch_names' do
|
|
describe 'within the same project' do
|
|
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
|
|
|
|
describe 'within different projects' do
|
|
let(:project) { create(:project) }
|
|
let(:forked_project) { fork_project(project) }
|
|
let(:merge_request) { create(:merge_request, source_project: forked_project, target_project: project) }
|
|
subject { format_mr_branch_names(merge_request) }
|
|
|
|
let(:source_title) { "#{forked_project.full_path}:#{merge_request.source_branch}" }
|
|
let(:target_title) { "#{project.full_path}:#{merge_request.target_branch}" }
|
|
|
|
it { is_expected.to eq([source_title, target_title]) }
|
|
end
|
|
end
|
|
|
|
describe '#tab_link_for' do
|
|
let(:merge_request) { create(:merge_request, :simple) }
|
|
let(:options) { {} }
|
|
|
|
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="tabvue"/)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#user_merge_requests_counts' do
|
|
let(:user) do
|
|
double(
|
|
assigned_open_merge_requests_count: 1,
|
|
review_requested_open_merge_requests_count: 2
|
|
)
|
|
end
|
|
|
|
subject { helper.user_merge_requests_counts }
|
|
|
|
before do
|
|
allow(helper).to receive(:current_user).and_return(user)
|
|
end
|
|
|
|
it "returns assigned, review requested and total merge request counts" do
|
|
expect(subject).to eq(
|
|
assigned: user.assigned_open_merge_requests_count,
|
|
review_requested: user.review_requested_open_merge_requests_count,
|
|
total: user.assigned_open_merge_requests_count + user.review_requested_open_merge_requests_count
|
|
)
|
|
end
|
|
|
|
context 'when merge_request_reviewers is disabled' do
|
|
before do
|
|
stub_feature_flags(merge_request_reviewers: false)
|
|
end
|
|
|
|
it 'returns review_requested as 0' do
|
|
expect(subject[:review_requested]).to eq(0)
|
|
end
|
|
end
|
|
end
|
|
end
|