2020-07-16 11:09:38 -04:00
# frozen_string_literal: true
require 'spec_helper'
RSpec . describe NamespaceSetting , type : :model do
2020-10-08 20:08:41 -04:00
# Relationships
#
2020-10-13 11:08:53 -04:00
describe " Associations " do
it { is_expected . to belong_to ( :namespace ) }
end
2020-10-08 20:08:41 -04:00
describe " validations " do
describe " # default_branch_name_content " do
let_it_be ( :group ) { create ( :group ) }
let ( :namespace_settings ) { group . namespace_settings }
shared_examples " doesn't return an error " do
it " doesn't return an error " do
expect ( namespace_settings . valid? ) . to be_truthy
expect ( namespace_settings . errors . full_messages ) . to be_empty
end
end
context " when not set " do
it_behaves_like " doesn't return an error "
end
context " when set " do
before do
namespace_settings . default_branch_name = " example_branch_name "
end
it_behaves_like " doesn't return an error "
end
context " when an empty string " do
before do
2020-11-04 10:08:41 -05:00
namespace_settings . default_branch_name = " "
2020-10-08 20:08:41 -04:00
end
2020-11-04 10:08:41 -05:00
it_behaves_like " doesn't return an error "
2020-10-08 20:08:41 -04:00
end
end
2020-10-13 11:08:53 -04:00
describe '#allow_mfa_for_group' do
let ( :settings ) { group . namespace_settings }
context 'group is top-level group' do
let ( :group ) { create ( :group ) }
it 'is valid' do
settings . allow_mfa_for_subgroups = false
expect ( settings ) . to be_valid
end
end
context 'group is a subgroup' do
let ( :group ) { create ( :group , parent : create ( :group ) ) }
it 'is invalid' do
settings . allow_mfa_for_subgroups = false
expect ( settings ) . to be_invalid
end
end
end
2021-04-05 23:09:02 -04:00
describe '#allow_resource_access_token_creation_for_group' do
let ( :settings ) { group . namespace_settings }
context 'group is top-level group' do
let ( :group ) { create ( :group ) }
it 'is valid' do
settings . resource_access_token_creation_allowed = false
expect ( settings ) . to be_valid
end
end
context 'group is a subgroup' do
let ( :group ) { create ( :group , parent : create ( :group ) ) }
it 'is invalid when resource access token creation is not enabled' do
settings . resource_access_token_creation_allowed = false
expect ( settings ) . to be_invalid
expect ( group . namespace_settings . errors . messages [ :resource_access_token_creation_allowed ] ) . to include ( " is not allowed since the group is not top-level group. " )
end
it 'is valid when resource access tokens are enabled' do
settings . resource_access_token_creation_allowed = true
expect ( settings ) . to be_valid
end
end
end
2020-10-08 20:08:41 -04:00
end
2020-07-16 11:09:38 -04:00
end