Commit 2ac65b13 authored by Kamil Trzciński's avatar Kamil Trzciński

Fix specs

parent ef6b8a8c
...@@ -28,8 +28,8 @@ module EE ...@@ -28,8 +28,8 @@ module EE
dependency_scanning: %i[dependency_scanning], dependency_scanning: %i[dependency_scanning],
container_scanning: %i[container_scanning sast_container], container_scanning: %i[container_scanning sast_container],
dast: %i[dast], dast: %i[dast],
performance: %i[:merge_request_performance_metrics], performance: %i[merge_request_performance_metrics],
license_management: nil license_management: %i[license_management]
}.freeze }.freeze
# Deprecated, to be removed in 12.0 # Deprecated, to be removed in 12.0
......
...@@ -6,9 +6,25 @@ FactoryBot.define do ...@@ -6,9 +6,25 @@ FactoryBot.define do
failure_reason { Ci::Build.failure_reasons[:protected_environment_failure] } failure_reason { Ci::Build.failure_reasons[:protected_environment_failure] }
end end
trait :security_reports do %i[sast performance license_management].each do |report_type|
trait "legacy_#{report_type}".to_sym do
success
artifacts
name report_type
options do
{
artifacts: {
paths: [Ci::JobArtifact::DEFAULT_FILE_NAMES[report_type]]
}
}
end
end
trait report_type do
after(:build) do |build| after(:build) do |build|
build.job_artifacts << create(:ee_ci_job_artifact, :sast, job: build) build.job_artifacts << build(:ee_ci_job_artifact, report_type, job: build)
end
end end
end end
end end
......
require 'spec_helper' require 'spec_helper'
describe MergeRequestWidgetEntity do describe MergeRequestWidgetEntity do
let(:user) { create(:user) } set(:user) { create(:user) }
let(:project) { create :project, :repository } set(:project) { create :project, :repository }
let(:merge_request) { create(:merge_request, source_project: project, target_project: project) } set(:merge_request) { create(:merge_request, source_project: project, target_project: project) }
set(:pipeline) { create(:ci_empty_pipeline, project: project) }
let(:request) { double('request', current_user: user) } let(:request) { double('request', current_user: user) }
let(:pipeline) { create(:ci_empty_pipeline, project: project) }
before do before do
project.add_developer(user) project.add_developer(user)
...@@ -39,6 +39,8 @@ describe MergeRequestWidgetEntity do ...@@ -39,6 +39,8 @@ describe MergeRequestWidgetEntity do
:dependency_scanning | :dependency_scanning :dependency_scanning | :dependency_scanning
:sast_container | :container_scanning :sast_container | :container_scanning
:dast | :dast :dast | :dast
:license_management | :license_management
:performance | :performance
end end
with_them do with_them do
...@@ -54,7 +56,7 @@ describe MergeRequestWidgetEntity do ...@@ -54,7 +56,7 @@ describe MergeRequestWidgetEntity do
allow(pipeline).to receive(:available_licensed_report_type?).and_return(true) allow(pipeline).to receive(:available_licensed_report_type?).and_return(true)
end end
context "with data" do context "with new report artifacts" do
before do before do
job = create(:ci_build, pipeline: pipeline) job = create(:ci_build, pipeline: pipeline)
create(:ci_job_artifact, file_type: artifact_type, file_format: Ci::JobArtifact::TYPE_AND_FORMAT_PAIRS[artifact_type], job: job) create(:ci_job_artifact, file_type: artifact_type, file_format: Ci::JobArtifact::TYPE_AND_FORMAT_PAIRS[artifact_type], job: job)
...@@ -65,7 +67,27 @@ describe MergeRequestWidgetEntity do ...@@ -65,7 +67,27 @@ describe MergeRequestWidgetEntity do
end end
end end
context "without data" do context "with legacy report artifacts" do
before do
create(:ci_build,
:success,
:artifacts,
pipeline: pipeline,
name: artifact_type,
options: {
artifacts: {
paths: [Ci::JobArtifact::DEFAULT_FILE_NAMES[artifact_type]]
}
}
)
end
it "has data entry" do
expect(subject.as_json).to include(json_entry)
end
end
context "without artifacts" do
it "does not have data entry" do it "does not have data entry" do
expect(subject.as_json).not_to include(json_entry) expect(subject.as_json).not_to include(json_entry)
end end
...@@ -76,17 +98,21 @@ describe MergeRequestWidgetEntity do ...@@ -76,17 +98,21 @@ describe MergeRequestWidgetEntity do
describe '#license_management' do describe '#license_management' do
before do before do
build = create(:ci_build, pipeline: pipeline) allow(merge_request).to receive_messages(
create(:ee_ci_job_artifact, :license_management, job: build) head_pipeline: pipeline, target_project: project)
stub_licensed_features(license_management: true)
end end
it 'should not be included, if license management features are off' do it 'should not be included, if missing artifacts' do
allow(merge_request).to receive_messages(expose_license_management_data?: false)
expect(subject.as_json).not_to include(:license_management) expect(subject.as_json).not_to include(:license_management)
end end
it 'should be included, if license manage management features are on' do context 'when report artifact is defined' do
before do
create(:ee_ci_build, :license_management, pipeline: pipeline)
end
it 'should be included' do
expect(subject.as_json).to include(:license_management) expect(subject.as_json).to include(:license_management)
expect(subject.as_json[:license_management]).to include(:head_path) expect(subject.as_json[:license_management]).to include(:head_path)
expect(subject.as_json[:license_management]).to include(:base_path) expect(subject.as_json[:license_management]).to include(:base_path)
...@@ -95,17 +121,46 @@ describe MergeRequestWidgetEntity do ...@@ -95,17 +121,46 @@ describe MergeRequestWidgetEntity do
expect(subject.as_json[:license_management]).to include(:license_management_full_report_path) expect(subject.as_json[:license_management]).to include(:license_management_full_report_path)
end end
context 'when feature is not licensed' do
before do
stub_licensed_features(license_management: false)
end
it 'should not be included' do
expect(subject.as_json).not_to include(:license_management)
end
end
it '#license_management_settings_path should not be included for developers' do it '#license_management_settings_path should not be included for developers' do
expect(subject.as_json[:license_management]).not_to include(:license_management_settings_path) expect(subject.as_json[:license_management]).not_to include(:license_management_settings_path)
end end
it '#license_management_settings_path should be included for maintainers' do context 'when user is maintainer' do
stub_licensed_features(license_management: true) before do
project.add_maintainer(user) project.add_maintainer(user)
end
it '#license_management_settings_path should be included for maintainers' do
expect(subject.as_json[:license_management]).to include(:license_management_settings_path) expect(subject.as_json[:license_management]).to include(:license_management_settings_path)
end end
end end
end
context 'when legacy artifact is defined' do
before do
create(:ee_ci_build, :legacy_license_management, pipeline: pipeline)
end
it 'should be included, if license manage management features are on' do
expect(subject.as_json).to include(:license_management)
expect(subject.as_json[:license_management]).to include(:head_path)
expect(subject.as_json[:license_management]).to include(:base_path)
expect(subject.as_json[:license_management]).to include(:managed_licenses_path)
expect(subject.as_json[:license_management]).to include(:can_manage_licenses)
expect(subject.as_json[:license_management]).to include(:license_management_full_report_path)
end
end
end
it 'has vulnerability feedbacks path' do it 'has vulnerability feedbacks path' do
expect(subject.as_json).to include(:vulnerability_feedback_path) expect(subject.as_json).to include(:vulnerability_feedback_path)
......
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