# frozen_string_literal: true require 'spec_helper' RSpec.describe ProjectSetting, type: :model do using RSpec::Parameterized::TableSyntax it { is_expected.to belong_to(:project) } 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 '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 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 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 end