Commit 70a421b4 authored by Mehmet Emin INAC's avatar Mehmet Emin INAC

Refactor `Project#latest_pipeline_with_security_reports` spec

parent c478e875
......@@ -1687,59 +1687,71 @@ RSpec.describe Project do
end
describe '#latest_pipeline_with_security_reports' do
let(:only_successful) { false }
let_it_be(:project) { create(:project) }
let_it_be(:project, refind: true) { create(:project) }
let_it_be(:pipeline_1) { create(:ci_pipeline, :success, project: project) }
let_it_be(:pipeline_2) { create(:ci_pipeline, project: project) }
let_it_be(:pipeline_3) { create(:ci_pipeline, :success, project: project) }
subject { project.latest_pipeline_with_security_reports(only_successful: only_successful) }
context 'when all pipelines are used' do
context 'when the pipeline of `vulnerability_statistic` has been set' do
shared_examples_for 'on-the-fly latest_pipeline_with_security_reports calculation' do |expected:|
let(:expected_pipeline) { public_send(expected) }
context 'when legacy reports are used' do
before do
project.create_vulnerability_statistic(pipeline: pipeline_1)
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_1)
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_2)
end
it { is_expected.to eq(pipeline_1) }
it 'returns the latest pipeline with security reports' do
is_expected.to eq(expected_pipeline)
end
end
context 'when the pipeline of `vulnerability_statistic` has not been set' do
context 'when new reports are used' do
before do
project.vulnerability_statistic&.update!(pipeline: nil)
create(:ee_ci_build, :sast, pipeline: pipeline_1)
create(:ee_ci_build, :sast, pipeline: pipeline_2)
end
context 'when legacy reports are used' do
it 'returns the latest pipeline with security reports' do
is_expected.to eq(expected_pipeline)
end
context 'when legacy used' do
before do
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_1)
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_2)
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_3)
end
it 'returns the latest pipeline with security reports' do
is_expected.to eq(pipeline_2)
it 'prefers the new reports' do
is_expected.to eq(expected_pipeline)
end
end
end
end
context 'when new reports are used' do
before do
create(:ee_ci_build, :sast, pipeline: pipeline_1)
create(:ee_ci_build, :sast, pipeline: pipeline_2)
end
context 'when all pipelines are used' do
let(:only_successful) { false }
it 'returns the latest pipeline with security reports' do
is_expected.to eq(pipeline_2)
end
context 'when there is no associated `vulnerability_statistic` record with the project' do
it_behaves_like 'on-the-fly latest_pipeline_with_security_reports calculation', expected: :pipeline_2
end
context 'when legacy used' do
context 'when there is an associated `vulnerability_statistic` record with the project' do
context 'when the pipeline of `vulnerability_statistic` has not been set' do
it_behaves_like 'on-the-fly latest_pipeline_with_security_reports calculation', expected: :pipeline_2 do
before do
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_3)
create(:vulnerability_statistic, project: project, pipeline: nil)
end
end
end
it 'prefers the new reports' do
is_expected.to eq(pipeline_2)
end
context 'when the pipeline of `vulnerability_statistic` has been set' do
before do
create(:vulnerability_statistic, project: project, pipeline: pipeline_1)
end
it { is_expected.to eq(pipeline_1) }
end
end
end
......@@ -1747,37 +1759,11 @@ RSpec.describe Project do
context 'when only successful pipelines are used' do
let(:only_successful) { true }
context 'when legacy reports are used' do
before do
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_1)
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_2)
end
it "returns the latest succesful pipeline with security reports" do
is_expected.to eq(pipeline_1)
end
before do
create(:vulnerability_statistic, project: project, pipeline: pipeline_2)
end
context 'when new reports are used' do
before do
create(:ee_ci_build, :sast, pipeline: pipeline_1)
create(:ee_ci_build, :sast, pipeline: pipeline_2)
end
it 'returns the latest successful pipeline with security reports' do
is_expected.to eq(pipeline_1)
end
context 'when legacy used' do
before do
create(:ee_ci_build, :legacy_sast, pipeline: pipeline_3)
end
it 'prefers the new reports' do
is_expected.to eq(pipeline_1)
end
end
end
it_behaves_like 'on-the-fly latest_pipeline_with_security_reports calculation', expected: :pipeline_1
end
end
......
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