226 lines
7.7 KiB
Ruby
226 lines
7.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe FormHelper do
|
|
include Devise::Test::ControllerHelpers
|
|
|
|
describe '#dropdown_max_select' do
|
|
let(:feature_flag) { :limit_reviewer_and_assignee_size }
|
|
|
|
context "with the :limit_reviewer_and_assignee_size feature flag on" do
|
|
before do
|
|
stub_feature_flags(feature_flag => true)
|
|
end
|
|
|
|
it 'correctly returns the max amount of reviewers or assignees to allow' do
|
|
max = Issuable::MAX_NUMBER_OF_ASSIGNEES_OR_REVIEWERS
|
|
|
|
expect(helper.dropdown_max_select({}, feature_flag))
|
|
.to eq(max)
|
|
expect(helper.dropdown_max_select({ 'max-select'.to_sym => 5 }, feature_flag))
|
|
.to eq(5)
|
|
expect(helper.dropdown_max_select({ 'max-select'.to_sym => max + 5 }, feature_flag))
|
|
.to eq(max)
|
|
end
|
|
end
|
|
|
|
context "with the :limit_reviewer_and_assignee_size feature flag off" do
|
|
before do
|
|
stub_feature_flags(feature_flag => false)
|
|
end
|
|
|
|
it 'correctly returns the max amount of reviewers or assignees to allow' do
|
|
expect(helper.dropdown_max_select({}, feature_flag))
|
|
.to eq(nil)
|
|
expect(helper.dropdown_max_select({ 'max-select'.to_sym => 5 }, feature_flag))
|
|
.to eq(5)
|
|
expect(helper.dropdown_max_select({ 'max-select'.to_sym => 120 }, feature_flag))
|
|
.to eq(120)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#assignees_dropdown_options' do
|
|
let(:merge_request) { build(:merge_request) }
|
|
|
|
context "with multiple assignees" do
|
|
it 'correctly returns the max amount of assignees to allow' do
|
|
allow(helper).to receive(:merge_request_supports_multiple_assignees?).and_return(true)
|
|
|
|
expect(helper.assignees_dropdown_options(:merge_request)[:data][:'max-select'])
|
|
.to eq(Issuable::MAX_NUMBER_OF_ASSIGNEES_OR_REVIEWERS)
|
|
end
|
|
end
|
|
|
|
context "with only 1 assignee" do
|
|
it 'correctly returns the max amount of assignees to allow' do
|
|
expect(helper.assignees_dropdown_options(:merge_request)[:data][:'max-select'])
|
|
.to eq(1)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#reviewers_dropdown_options' do
|
|
let(:merge_request) { build(:merge_request) }
|
|
|
|
context "with the :limit_reviewer_and_assignee_size feature flag on" do
|
|
context "with multiple reviewers" do
|
|
it 'correctly returns the max amount of reviewers or assignees to allow' do
|
|
allow(helper).to receive(:merge_request_supports_multiple_reviewers?).and_return(true)
|
|
|
|
expect(helper.reviewers_dropdown_options(merge_request)[:data][:'max-select'])
|
|
.to eq(Issuable::MAX_NUMBER_OF_ASSIGNEES_OR_REVIEWERS)
|
|
end
|
|
end
|
|
|
|
context "with only 1 reviewer" do
|
|
it 'correctly returns the max amount of reviewers or assignees to allow' do
|
|
expect(helper.reviewers_dropdown_options(merge_request)[:data][:'max-select'])
|
|
.to eq(1)
|
|
end
|
|
end
|
|
end
|
|
|
|
context "with the :limit_reviewer_and_assignee_size feature flag off" do
|
|
before do
|
|
stub_feature_flags(limit_reviewer_and_assignee_size: false)
|
|
end
|
|
|
|
context "with multiple reviewers" do
|
|
it 'correctly returns the max amount of reviewers or assignees to allow' do
|
|
allow(helper).to receive(:merge_request_supports_multiple_reviewers?).and_return(true)
|
|
|
|
expect(helper.reviewers_dropdown_options(merge_request)[:data][:'max-select'])
|
|
.to eq(nil)
|
|
end
|
|
end
|
|
|
|
context "with only 1 reviewer" do
|
|
it 'correctly returns the max amount of reviewers or assignees to allow' do
|
|
expect(helper.reviewers_dropdown_options(merge_request)[:data][:'max-select'])
|
|
.to eq(1)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'form_errors' do
|
|
it 'returns nil when model has no errors' do
|
|
model = double(errors: [])
|
|
|
|
expect(helper.form_errors(model)).to be_nil
|
|
end
|
|
|
|
it 'renders an appropriately styled alert div' do
|
|
model = double(errors: errors_stub('Error 1'))
|
|
|
|
expect(helper.form_errors(model))
|
|
.to include(
|
|
'<div class="gl-alert gl-mb-5 gl-alert-danger gl-alert-not-dismissible" id="error_explanation" role="alert">'
|
|
)
|
|
end
|
|
|
|
it 'contains a summary message' do
|
|
single_error = double(errors: errors_stub('A'))
|
|
multi_errors = double(errors: errors_stub('A', 'B', 'C'))
|
|
|
|
expect(helper.form_errors(single_error))
|
|
.to include('The form contains the following error:')
|
|
expect(helper.form_errors(multi_errors))
|
|
.to include('The form contains the following errors:')
|
|
end
|
|
|
|
it 'renders each message' do
|
|
model = double(errors: errors_stub('Error 1', 'Error 2', 'Error 3'))
|
|
|
|
errors = helper.form_errors(model)
|
|
|
|
aggregate_failures do
|
|
expect(errors).to include('<li>Error 1</li>')
|
|
expect(errors).to include('<li>Error 2</li>')
|
|
expect(errors).to include('<li>Error 3</li>')
|
|
end
|
|
end
|
|
|
|
it 'renders messages truncated if requested' do
|
|
model = double(errors: errors_stub('Error 1', 'Error 2'))
|
|
model.errors.add(:title, 'is truncated')
|
|
model.errors.add(:base, 'Error 3')
|
|
|
|
expect(model.class).to receive(:human_attribute_name) do |attribute|
|
|
attribute.to_s.capitalize
|
|
end
|
|
|
|
errors = helper.form_errors(model, truncate: :title)
|
|
|
|
aggregate_failures do
|
|
expect(errors).to include('<li>Error 1</li>')
|
|
expect(errors).to include('<li>Error 2</li>')
|
|
expect(errors).to include('<li><span class="str-truncated-100">Title is truncated</span></li>')
|
|
expect(errors).to include('<li>Error 3</li>')
|
|
end
|
|
end
|
|
|
|
it 'renders custom messages without the attribute name prefix' do
|
|
model = double(errors: errors_stub('Error 1'))
|
|
model.errors.add(:name, 'is already taken')
|
|
model.errors.add(:code_name, 'This code name is not allowed')
|
|
|
|
allow(model.class).to receive(:human_attribute_name) do |attribute|
|
|
attribute.to_s.capitalize
|
|
end
|
|
|
|
errors = helper.form_errors(model, custom_message: [:code_name])
|
|
|
|
aggregate_failures do
|
|
expect(errors).to include('<li>Error 1</li>')
|
|
expect(errors).to include('<li>Name is already taken</li>')
|
|
expect(errors).to include('<li>This code name is not allowed</li>')
|
|
end
|
|
end
|
|
|
|
it 'renders help page links' do
|
|
stubbed_errors = ActiveModel::Errors.new(double).tap do |errors|
|
|
errors.add(:base, 'No text.', help_page_url: 'http://localhost/doc/user/index.html')
|
|
errors.add(
|
|
:base,
|
|
'With text.',
|
|
help_link_text: 'Documentation page title.',
|
|
help_page_url: 'http://localhost/doc/administration/index.html'
|
|
)
|
|
errors.add(
|
|
:base,
|
|
'With HTML text.',
|
|
help_link_text: '<foo>',
|
|
help_page_url: 'http://localhost/doc/security/index.html'
|
|
)
|
|
end
|
|
|
|
model = double(errors: stubbed_errors)
|
|
|
|
errors = helper.form_errors(model)
|
|
|
|
aggregate_failures do
|
|
expect(errors).to include(
|
|
'<li>No text. <a target="_blank" rel="noopener noreferrer" ' \
|
|
'href="http://localhost/doc/user/index.html">Learn more.</a></li>'
|
|
)
|
|
expect(errors).to include(
|
|
'<li>With text. <a target="_blank" rel="noopener noreferrer" ' \
|
|
'href="http://localhost/doc/administration/index.html">Documentation page title.</a></li>'
|
|
)
|
|
expect(errors).to include(
|
|
'<li>With HTML text. <a target="_blank" rel="noopener noreferrer" ' \
|
|
'href="http://localhost/doc/security/index.html"><foo></a></li>'
|
|
)
|
|
end
|
|
end
|
|
|
|
def errors_stub(*messages)
|
|
ActiveModel::Errors.new(double).tap do |errors|
|
|
messages.each { |msg| errors.add(:base, msg) }
|
|
end
|
|
end
|
|
end
|
|
end
|