Commit 14311583 authored by Matthias Käppler's avatar Matthias Käppler

Merge branch '333113-backend-fixes' into 'master'

Fix multiple issues for Security Configuration

See merge request gitlab-org/gitlab!79882
parents 56f0d1ad 817065db
......@@ -80,7 +80,8 @@ module Projects
type: scan.type,
configured: scan.configured?,
configuration_path: scan.configuration_path,
available: scan.available?
available: scan.available?,
can_enable_in_merge_request: scan.can_enable_in_merge_request?
}
end
......
......@@ -193,6 +193,7 @@ class License < ApplicationRecord
sast_custom_rulesets
sast_fp_reduction
secret_detection
security_configuration_in_ui
security_dashboard
security_on_demand_scans
security_orchestration_policies
......
......@@ -13,25 +13,30 @@ module EE
override :configuration_path
def configuration_path
super if available? || always_available?
configurable_scans[type] if can_configure_scan_in_ui?
end
private
override :configurable_scans
def can_configure_scan_in_ui?
project.licensed_feature_available?(:security_configuration_in_ui)
end
def configurable_scans
strong_memoize(:configurable_scans) do
{
sast: project_security_configuration_sast_path(project),
dast: project_security_configuration_dast_path(project),
dast_profiles: project_security_configuration_dast_scans_path(project),
api_fuzzing: project_security_configuration_api_fuzzing_path(project),
corpus_management: (project_security_configuration_corpus_management_path(project) if ::Feature.enabled?(:corpus_management_ui, project, default_enabled: :yaml))
}.merge(super)
}
end
end
def always_available?
[:corpus_management, :dast_profiles].include?(type)
override :scans_configurable_in_merge_request
def scans_configurable_in_merge_request
super.concat(%i[dependency_scanning container_scanning])
end
end
end
......
......@@ -19,7 +19,7 @@ RSpec.describe 'User sees Security Configuration table', :js do
before do
stub_licensed_features(security_dashboard: true, sast: true, sast_iac: true, dast: true,
dependency_scanning: true, container_scanning: true, coverage_fuzzing: true,
cluster_image_scanning: true, api_fuzzing: true)
cluster_image_scanning: true, api_fuzzing: true, security_configuration_in_ui: true)
end
context 'with no SAST report' do
......
......@@ -3,15 +3,15 @@
require 'spec_helper'
RSpec.describe ::Gitlab::Security::ScanConfiguration do
using RSpec::Parameterized::TableSyntax
let_it_be(:project) { create(:project, :repository) }
let(:scan) { described_class.new(project: project, type: type, configured: configured) }
let(:scan) { described_class.new(project: project, type: type) }
describe '#available?' do
subject { scan.available? }
let(:configured) { true }
context 'with a core scanner' do
let(:type) { :sast }
......@@ -54,24 +54,25 @@ RSpec.describe ::Gitlab::Security::ScanConfiguration do
describe '#configuration_path' do
subject { scan.configuration_path }
let(:configured) { true }
context 'when configuration in UI is available' do
before do
stub_licensed_features(security_configuration_in_ui: true)
end
context 'with licensed scanner' do
let(:type) { :dast }
let(:configuration_path) { "/#{project.namespace.path}/#{project.name}/-/security/configuration/dast" }
let(:path) { "/#{project.namespace.path}/#{project.name}/-/security/configuration" }
before do
stub_licensed_features(dast: true)
where(:type, :configuration_path) do
:sast | lazy { "#{path}/sast" }
:dast | lazy { "#{path}/dast" }
:dast_profiles | lazy { "#{path}/dast_scans" }
:api_fuzzing | lazy { "#{path}/api_fuzzing" }
:corpus_management | lazy { "#{path}/corpus_management" }
end
with_them do
it { is_expected.to eq(configuration_path) }
end
context 'with always available scanner' do
let(:type) { :dast_profiles }
let(:configuration_path) { "/#{project.namespace.path}/#{project.name}/-/security/configuration/dast_scans" }
it { is_expected.to eq(configuration_path) }
end
context 'with a scanner under feature flag' do
......@@ -89,4 +90,29 @@ RSpec.describe ::Gitlab::Security::ScanConfiguration do
end
end
end
context 'when configuration in UI is not available' do
let(:type) { :sast }
it { is_expected.to be_nil }
end
end
describe '#can_enable_in_merge_request?' do
subject { scan.can_enable_in_merge_request? }
context 'with a scanner that can be enabled in merge request' do
where(type: %i(sast sast_iac secret_detection dependency_scanning container_scanning))
with_them do
it { is_expected.to be_truthy }
end
end
context 'with a scanner that can not be enabled in merge request' do
let(:type) { :dast }
it { is_expected.to be_falsey }
end
end
end
......@@ -18,27 +18,25 @@ module Gitlab
# SAST and Secret Detection are always available, but this isn't
# reflected by our license model yet.
# TODO: https://gitlab.com/gitlab-org/gitlab/-/issues/333113
%i[sast secret_detection].include?(type)
%i[sast sast_iac secret_detection].include?(type)
end
def can_enable_in_merge_request?
scans_configurable_in_merge_request.include?(type)
end
def configured?
configured
end
def configuration_path
configurable_scans[type]
end
def configuration_path; end
private
attr_reader :project, :configured
def configurable_scans
strong_memoize(:configurable_scans) do
{
sast: project_security_configuration_sast_path(project)
}
end
def scans_configurable_in_merge_request
%i[sast sast_iac secret_detection]
end
end
end
......
......@@ -3,6 +3,8 @@
require 'spec_helper'
RSpec.describe ::Gitlab::Security::ScanConfiguration do
using RSpec::Parameterized::TableSyntax
let_it_be(:project) { create(:project, :repository) }
let(:scan) { described_class.new(project: project, type: type, configured: configured) }
......@@ -13,10 +15,12 @@ RSpec.describe ::Gitlab::Security::ScanConfiguration do
let(:configured) { true }
context 'with a core scanner' do
let(:type) { :sast }
where(type: %i(sast sast_iac secret_detection))
with_them do
it { is_expected.to be_truthy }
end
end
context 'with custom scanner' do
let(:type) { :my_scanner }
......@@ -38,27 +42,28 @@ RSpec.describe ::Gitlab::Security::ScanConfiguration do
subject { scan.configuration_path }
let(:configured) { true }
context 'with a non configurable scanner' do
let(:type) { :secret_detection }
let(:type) { :sast }
it { is_expected.to be_nil }
end
context 'with licensed scanner for FOSS environment' do
let(:type) { :dast }
describe '#can_enable_in_merge_request?' do
subject { scan.can_enable_in_merge_request? }
before do
stub_env('FOSS_ONLY', '1')
end
let(:configured) { true }
it { is_expected.to be_nil }
context 'with a core scanner' do
where(type: %i(sast sast_iac secret_detection))
with_them do
it { is_expected.to be_truthy }
end
end
context 'with custom scanner' do
context 'with a custom scanner' do
let(:type) { :my_scanner }
it { is_expected.to be_nil }
it { is_expected.to be_falsey }
end
end
end
......@@ -86,8 +86,9 @@ RSpec.describe Projects::Security::ConfigurationPresenter do
expect(feature['type']).to eq('sast')
expect(feature['configured']).to eq(true)
expect(feature['configuration_path']).to eq(project_security_configuration_sast_path(project))
expect(feature['configuration_path']).to be_nil
expect(feature['available']).to eq(true)
expect(feature['can_enable_in_merge_request']).to eq(true)
end
context 'when checking features configured status' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment