diff options
author | Mark Chao <mchao@gitlab.com> | 2019-09-16 17:50:41 +0800 |
---|---|---|
committer | Mark Chao <mchao@gitlab.com> | 2019-10-01 17:19:39 +1300 |
commit | ccb6a5a56e722337fe5ea242a91829ea52e15c0c (patch) | |
tree | 5baeb2b752f0ab712b9f110150ec4ccdd6c14d97 /spec/models/project_feature_spec.rb | |
parent | f84dc8c1a1c40943ef991ecd5c7493b4aa8410de (diff) | |
download | gitlab-ce-ccb6a5a56e722337fe5ea242a91829ea52e15c0c.tar.gz |
EE port: Fix private feature Elasticsearch leak
Add spec to test different combinations.
Accept string for required_minimum_access_level
Allow more flexible project membership query
Diffstat (limited to 'spec/models/project_feature_spec.rb')
-rw-r--r-- | spec/models/project_feature_spec.rb | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/spec/models/project_feature_spec.rb b/spec/models/project_feature_spec.rb index 31e55bf6be6..84f13c44826 100644 --- a/spec/models/project_feature_spec.rb +++ b/spec/models/project_feature_spec.rb @@ -178,4 +178,28 @@ describe ProjectFeature do it { is_expected.to eq(ProjectFeature::ENABLED) } end end + + describe '.required_minimum_access_level' do + it 'handles reporter level' do + expect(described_class.required_minimum_access_level(:merge_requests)).to eq(Gitlab::Access::REPORTER) + end + + it 'handles guest level' do + expect(described_class.required_minimum_access_level(:issues)).to eq(Gitlab::Access::GUEST) + end + + it 'accepts ActiveModel' do + expect(described_class.required_minimum_access_level(MergeRequest)).to eq(Gitlab::Access::REPORTER) + end + + it 'accepts string' do + expect(described_class.required_minimum_access_level('merge_requests')).to eq(Gitlab::Access::REPORTER) + end + + it 'raises error if feature is invalid' do + expect do + described_class.required_minimum_access_level(:foos) + end.to raise_error + end + end end |