Commit e2a74490 authored by Alan (Maciej) Paruszewski's avatar Alan (Maciej) Paruszewski Committed by Stan Hu

Update pipeline when vulnerability dismissal feedback is created

parent 8ba7dfae
...@@ -370,6 +370,7 @@ export const revertDismissVulnerability = ({ state, dispatch }) => { ...@@ -370,6 +370,7 @@ export const revertDismissVulnerability = ({ state, dispatch }) => {
...state.modal.vulnerability, ...state.modal.vulnerability,
isDismissed: false, isDismissed: false,
dismissalFeedback: null, dismissalFeedback: null,
dismissal_feedback: null,
}; };
dispatch('receiveDismissVulnerability', updatedIssue); dispatch('receiveDismissVulnerability', updatedIssue);
......
...@@ -34,6 +34,9 @@ module Vulnerabilities ...@@ -34,6 +34,9 @@ module Vulnerabilities
preload(:author, :comment_author, :project, :issue, :merge_request, :pipeline) preload(:author, :comment_author, :project, :issue, :merge_request, :pipeline)
end end
after_save :touch_pipeline, if: :for_dismissal?
after_destroy :touch_pipeline, if: :for_dismissal?
# TODO remove once filtered data has been cleaned # TODO remove once filtered data has been cleaned
def self.only_valid_feedback def self.only_valid_feedback
pipeline = Ci::Pipeline.arel_table pipeline = Ci::Pipeline.arel_table
...@@ -83,5 +86,9 @@ module Vulnerabilities ...@@ -83,5 +86,9 @@ module Vulnerabilities
project_fingerprint: project_fingerprint project_fingerprint: project_fingerprint
} }
end end
def touch_pipeline
pipeline&.touch
end
end end
end end
...@@ -39,7 +39,8 @@ module Vulnerabilities ...@@ -39,7 +39,8 @@ module Vulnerabilities
category: finding.report_type, category: finding.report_type,
feedback_type: 'dismissal', feedback_type: 'dismissal',
project_fingerprint: finding.project_fingerprint, project_fingerprint: finding.project_fingerprint,
comment: @comment comment: @comment,
pipeline: @project.latest_pipeline_with_security_reports(only_successful: true)
} }
end end
......
---
title: Update pipeline when vulnerability dismissal feedback is created
merge_request: 45954
author:
type: fixed
...@@ -94,6 +94,7 @@ const createNonDismissedVulnerability = options => ...@@ -94,6 +94,7 @@ const createNonDismissedVulnerability = options =>
...options, ...options,
isDismissed: false, isDismissed: false,
dismissalFeedback: null, dismissalFeedback: null,
dismissal_feedback: null,
}); });
const createDismissedVulnerability = options => const createDismissedVulnerability = options =>
......
...@@ -11,6 +11,8 @@ RSpec.describe Vulnerabilities::DismissService do ...@@ -11,6 +11,8 @@ RSpec.describe Vulnerabilities::DismissService do
let_it_be(:user) { create(:user) } let_it_be(:user) { create(:user) }
let(:project) { create(:project) } # cannot use let_it_be here: caching causes problems with permission-related tests let(:project) { create(:project) } # cannot use let_it_be here: caching causes problems with permission-related tests
let!(:pipeline) { create(:ci_pipeline, :success, project: project) }
let!(:build) { create(:ee_ci_build, :sast, pipeline: pipeline) }
let(:vulnerability) { create(:vulnerability, :with_findings, project: project) } let(:vulnerability) { create(:vulnerability, :with_findings, project: project) }
let(:service) { described_class.new(user, vulnerability) } let(:service) { described_class.new(user, vulnerability) }
...@@ -46,7 +48,7 @@ RSpec.describe Vulnerabilities::DismissService do ...@@ -46,7 +48,7 @@ RSpec.describe Vulnerabilities::DismissService do
have_attributes(state: 'dismissed', dismissed_by: user, dismissed_at: be_like_time(Time.current))) have_attributes(state: 'dismissed', dismissed_by: user, dismissed_at: be_like_time(Time.current)))
expect(vulnerability.findings).to all have_vulnerability_dismissal_feedback expect(vulnerability.findings).to all have_vulnerability_dismissal_feedback
expect(vulnerability.findings.map(&:dismissal_feedback)).to( expect(vulnerability.findings.map(&:dismissal_feedback)).to(
all(have_attributes(comment: comment, comment_author: user, comment_timestamp: be_like_time(Time.current)))) all(have_attributes(comment: comment, comment_author: user, comment_timestamp: be_like_time(Time.current), pipeline_id: pipeline.id)))
end end
end end
end end
......
...@@ -60,6 +60,10 @@ RSpec.describe VulnerabilityFeedback::CreateService, '#execute' do ...@@ -60,6 +60,10 @@ RSpec.describe VulnerabilityFeedback::CreateService, '#execute' do
expect(feedback.merge_request).to be_nil expect(feedback.merge_request).to be_nil
end end
it 'touches pipeline related to feedback' do
expect { result }.to change { pipeline.reload.updated_at }
end
context 'when feedback params has a comment' do context 'when feedback params has a comment' do
it 'sets the comment attributes' do it 'sets the comment attributes' do
feedback = result[:vulnerability_feedback] feedback = result[:vulnerability_feedback]
......
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