debian-mirror-gitlab/spec/models/project_setting_spec.rb

265 lines
9.5 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe ProjectSetting, type: :model, feature_category: :projects do
using RSpec::Parameterized::TableSyntax
it { is_expected.to belong_to(:project) }
describe 'default values' do
it { expect(subject.legacy_open_source_license_available).to be_truthy }
end
describe 'scopes' do
let_it_be(:project_1) { create(:project) }
let_it_be(:project_2) { create(:project) }
let_it_be(:project_setting_1) { create(:project_setting, project: project_1) }
let_it_be(:project_setting_2) { create(:project_setting, project: project_2) }
it 'returns project setting for the given projects' do
expect(described_class.for_projects(project_1)).to contain_exactly(project_setting_1)
end
end
describe 'validations' do
it { is_expected.not_to allow_value(nil).for(:target_platforms) }
it { is_expected.to allow_value([]).for(:target_platforms) }
it { is_expected.to validate_length_of(:issue_branch_template).is_at_most(255) }
it { is_expected.not_to allow_value(nil).for(:suggested_reviewers_enabled) }
it { is_expected.to allow_value(true).for(:suggested_reviewers_enabled) }
it { is_expected.to allow_value(false).for(:suggested_reviewers_enabled) }
it 'allows any combination of the allowed target platforms' do
valid_target_platform_combinations.each do |target_platforms|
expect(subject).to allow_value(target_platforms).for(:target_platforms)
end
end
[nil, 'not_allowed', :invalid].each do |invalid_value|
it { is_expected.not_to allow_value([invalid_value]).for(:target_platforms) }
end
context "when pages_unique_domain is required", feature_category: :pages do
it "is not required if pages_unique_domain_enabled is false" do
project_setting = build(:project_setting, pages_unique_domain_enabled: false)
expect(project_setting).to be_valid
expect(project_setting.errors.full_messages).not_to include("Pages unique domain can't be blank")
end
it "is required when pages_unique_domain_enabled is true" do
project_setting = build(:project_setting, pages_unique_domain_enabled: true)
expect(project_setting).not_to be_valid
expect(project_setting.errors.full_messages).to include("Pages unique domain can't be blank")
end
it "is required if it is already saved in the database" do
project_setting = create(
:project_setting,
pages_unique_domain: "random-unique-domain-here",
pages_unique_domain_enabled: true
)
project_setting.pages_unique_domain = nil
expect(project_setting).not_to be_valid
expect(project_setting.errors.full_messages).to include("Pages unique domain can't be blank")
end
end
it "validates uniqueness of pages_unique_domain", feature_category: :pages do
create(:project_setting, pages_unique_domain: "random-unique-domain-here")
project_setting = build(:project_setting, pages_unique_domain: "random-unique-domain-here")
expect(project_setting).not_to be_valid
expect(project_setting.errors.full_messages).to include("Pages unique domain has already been taken")
end
it "validates if the pages_unique_domain already exist as a project path" do
stub_pages_setting(host: 'example.com')
create(:project, path: "random-unique-domain.example.com")
project_setting = build(:project_setting, pages_unique_domain: "random-unique-domain")
expect(project_setting).not_to be_valid
expect(project_setting.errors.full_messages_for(:pages_unique_domain))
.to match(["Pages unique domain already in use"])
end
context "when updating" do
it "validates if the pages_unique_domain already exist as a project path" do
stub_pages_setting(host: 'example.com')
project_setting = create(:project_setting)
create(:project, path: "random-unique-domain.example.com")
expect(project_setting.update(pages_unique_domain: "random-unique-domain")).to eq(false)
expect(project_setting.errors.full_messages_for(:pages_unique_domain))
.to match(["Pages unique domain already in use"])
end
end
end
describe 'target_platforms=' do
it 'stringifies and sorts' do
project_setting = build(:project_setting, target_platforms: [:watchos, :ios])
expect(project_setting.target_platforms).to eq %w[ios watchos]
end
end
describe '#human_squash_option' do
where(:squash_option, :human_squash_option) do
'never' | 'Do not allow'
'always' | 'Require'
'default_on' | 'Encourage'
'default_off' | 'Allow'
end
with_them do
let(:project_setting) { create(:project_setting, squash_option: ProjectSetting.squash_options[squash_option]) }
subject { project_setting.human_squash_option }
it { is_expected.to eq(human_squash_option) }
end
end
def valid_target_platform_combinations
target_platforms = described_class::ALLOWED_TARGET_PLATFORMS
0.upto(target_platforms.size).flat_map do |n|
target_platforms.permutation(n).to_a
end
end
describe '#show_diff_preview_in_email?' do
context 'when a project is a top-level namespace' do
let(:project_settings) { create(:project_setting, show_diff_preview_in_email: false) }
let(:project) { create(:project, project_setting: project_settings) }
context 'when show_diff_preview_in_email is disabled' do
it 'returns false' do
expect(project).not_to be_show_diff_preview_in_email
end
end
context 'when show_diff_preview_in_email is enabled' do
let(:project_settings) { create(:project_setting, show_diff_preview_in_email: true) }
it 'returns true' do
settings = create(:project_setting, show_diff_preview_in_email: true)
project = create(:project, project_setting: settings)
expect(project).to be_show_diff_preview_in_email
end
end
end
describe '#emails_enabled?' do
context "when a project does not have a parent group" do
let(:project_settings) { create(:project_setting, emails_enabled: true) }
let(:project) { create(:project, project_setting: project_settings) }
it "returns true" do
expect(project.emails_enabled?).to be_truthy
end
it "returns false when updating project settings" do
project.update_attribute(:emails_disabled, false)
expect(project.emails_enabled?).to be_truthy
end
end
context "when a project has a parent group" do
let(:namespace_settings) { create(:namespace_settings, emails_enabled: true) }
let(:project_settings) { create(:project_setting, emails_enabled: true) }
let(:group) { create(:group, namespace_settings: namespace_settings) }
let(:project) do
create(:project, namespace_id: group.id,
project_setting: project_settings)
end
context 'when emails have been disabled in parent group' do
it 'returns false' do
group.update_attribute(:emails_disabled, true)
expect(project.emails_enabled?).to be_falsey
end
end
context 'when emails are enabled in parent group' do
before do
allow(project.namespace).to receive(:emails_enabled?).and_return(true)
end
it 'returns true' do
expect(project.emails_enabled?).to be_truthy
end
it 'returns false when disabled at the project' do
project.update_attribute(:emails_disabled, true)
expect(project.emails_enabled?).to be_falsey
end
end
end
end
context 'when a parent group has a parent group' do
let(:namespace_settings) { create(:namespace_settings, show_diff_preview_in_email: false) }
let(:project_settings) { create(:project_setting, show_diff_preview_in_email: true) }
let(:group) { create(:group, namespace_settings: namespace_settings) }
let!(:project) { create(:project, namespace_id: group.id, project_setting: project_settings) }
context 'when show_diff_preview_in_email is disabled for the parent group' do
it 'returns false' do
expect(project).not_to be_show_diff_preview_in_email
end
end
context 'when all ancestors have enabled diff previews' do
let(:namespace_settings) { create(:namespace_settings, show_diff_preview_in_email: true) }
it 'returns true' do
group.update_attribute(:show_diff_preview_in_email, true)
expect(project).to be_show_diff_preview_in_email
end
end
end
end
describe '#runner_registration_enabled' do
let_it_be(:settings) { create(:project_setting) }
let_it_be(:group) { create(:group) }
let_it_be(:project) { create(:project, project_setting: settings, group: group) }
it 'returns true' do
expect(project.runner_registration_enabled).to eq true
end
context 'when project has runner registration disabled' do
before do
project.update!(runner_registration_enabled: false)
end
it 'returns false' do
expect(project.runner_registration_enabled).to eq false
end
end
context 'when all projects have runner registration disabled' do
before do
stub_application_setting(valid_runner_registrars: ['group'])
end
it 'returns false' do
expect(project.runner_registration_enabled).to eq false
end
end
end
end