Commit dd1533c0 authored by Fernando Arias's avatar Fernando Arias Committed by Natalia Tepluhina

Update getter in group security reports

* Update getters to be aware of coverage fuzzing
parent ecefdd6e
...@@ -44,6 +44,7 @@ export const summaryCounts = ({ ...@@ -44,6 +44,7 @@ export const summaryCounts = ({
dependencyScanning, dependencyScanning,
sast, sast,
secretScanning, secretScanning,
coverageFuzzing,
} = {}) => { } = {}) => {
const allNewVulns = [ const allNewVulns = [
...containerScanning.newIssues, ...containerScanning.newIssues,
...@@ -51,6 +52,7 @@ export const summaryCounts = ({ ...@@ -51,6 +52,7 @@ export const summaryCounts = ({
...dependencyScanning.newIssues, ...dependencyScanning.newIssues,
...sast.newIssues, ...sast.newIssues,
...secretScanning.newIssues, ...secretScanning.newIssues,
...coverageFuzzing.newIssues,
]; ];
return countVulnerabilities(allNewVulns); return countVulnerabilities(allNewVulns);
...@@ -123,49 +125,56 @@ export const areReportsLoading = state => ...@@ -123,49 +125,56 @@ export const areReportsLoading = state =>
state.dast.isLoading || state.dast.isLoading ||
state.containerScanning.isLoading || state.containerScanning.isLoading ||
state.dependencyScanning.isLoading || state.dependencyScanning.isLoading ||
state.secretScanning.isLoading; state.secretScanning.isLoading ||
state.coverageFuzzing.isLoading;
export const areAllReportsLoading = state => export const areAllReportsLoading = state =>
state.sast.isLoading && state.sast.isLoading &&
state.dast.isLoading && state.dast.isLoading &&
state.containerScanning.isLoading && state.containerScanning.isLoading &&
state.dependencyScanning.isLoading && state.dependencyScanning.isLoading &&
state.secretScanning.isLoading; state.secretScanning.isLoading &&
state.coverageFuzzing.isLoading;
export const allReportsHaveError = state => export const allReportsHaveError = state =>
state.sast.hasError && state.sast.hasError &&
state.dast.hasError && state.dast.hasError &&
state.containerScanning.hasError && state.containerScanning.hasError &&
state.dependencyScanning.hasError && state.dependencyScanning.hasError &&
state.secretScanning.hasError; state.secretScanning.hasError &&
state.coverageFuzzing.hasError;
export const anyReportHasError = state => export const anyReportHasError = state =>
state.sast.hasError || state.sast.hasError ||
state.dast.hasError || state.dast.hasError ||
state.containerScanning.hasError || state.containerScanning.hasError ||
state.dependencyScanning.hasError || state.dependencyScanning.hasError ||
state.secretScanning.hasError; state.secretScanning.hasError ||
state.coverageFuzzing.hasError;
export const noBaseInAllReports = state => export const noBaseInAllReports = state =>
!state.sast.hasBaseReport && !state.sast.hasBaseReport &&
!state.dast.hasBaseReport && !state.dast.hasBaseReport &&
!state.containerScanning.hasBaseReport && !state.containerScanning.hasBaseReport &&
!state.dependencyScanning.hasBaseReport && !state.dependencyScanning.hasBaseReport &&
!state.secretScanning.hasBaseReport; !state.secretScanning.hasBaseReport &&
!state.coverageFuzzing.hasBaseReport;
export const anyReportHasIssues = state => export const anyReportHasIssues = state =>
state.sast.newIssues.length > 0 || state.sast.newIssues.length > 0 ||
state.dast.newIssues.length > 0 || state.dast.newIssues.length > 0 ||
state.containerScanning.newIssues.length > 0 || state.containerScanning.newIssues.length > 0 ||
state.dependencyScanning.newIssues.length > 0 || state.dependencyScanning.newIssues.length > 0 ||
state.secretScanning.newIssues.length > 0; state.secretScanning.newIssues.length > 0 ||
state.coverageFuzzing.newIssues.length > 0;
export const isBaseSecurityReportOutOfDate = state => export const isBaseSecurityReportOutOfDate = state =>
state.sast.baseReportOutofDate || state.sast.baseReportOutofDate ||
state.dast.baseReportOutofDate || state.dast.baseReportOutofDate ||
state.containerScanning.baseReportOutofDate || state.containerScanning.baseReportOutofDate ||
state.dependencyScanning.baseReportOutofDate || state.dependencyScanning.baseReportOutofDate ||
state.secretScanning.baseReportOutofDate; state.secretScanning.baseReportOutofDate ||
state.coverageFuzzing.baseReportOutofDate;
export const canCreateIssue = state => Boolean(state.createVulnerabilityFeedbackIssuePath); export const canCreateIssue = state => Boolean(state.createVulnerabilityFeedbackIssuePath);
......
...@@ -273,7 +273,7 @@ describe('Grouped security reports app', () => { ...@@ -273,7 +273,7 @@ describe('Grouped security reports app', () => {
// Renders the summary text // Renders the summary text
expect(wrapper.vm.$el.querySelector('.js-code-text').textContent.trim()).toEqual( expect(wrapper.vm.$el.querySelector('.js-code-text').textContent.trim()).toEqual(
'Security scanning detected 5 critical and 3 high severity vulnerabilities.', 'Security scanning detected 6 critical and 4 high severity vulnerabilities.',
); );
// Renders the expand button // Renders the expand button
......
...@@ -5,6 +5,7 @@ import { ...@@ -5,6 +5,7 @@ import {
groupedDastText, groupedDastText,
groupedDependencyText, groupedDependencyText,
groupedSecretScanningText, groupedSecretScanningText,
groupedCoverageFuzzingText,
groupedSummaryText, groupedSummaryText,
allReportsHaveError, allReportsHaveError,
noBaseInAllReports, noBaseInAllReports,
...@@ -44,6 +45,7 @@ describe('Security reports getters', () => { ...@@ -44,6 +45,7 @@ describe('Security reports getters', () => {
${'Dependency scanning'} | ${'dependencyScanning'} | ${groupedDependencyText} ${'Dependency scanning'} | ${'dependencyScanning'} | ${groupedDependencyText}
${'Container scanning'} | ${'containerScanning'} | ${groupedContainerScanningText} ${'Container scanning'} | ${'containerScanning'} | ${groupedContainerScanningText}
${'DAST'} | ${'dast'} | ${groupedDastText} ${'DAST'} | ${'dast'} | ${groupedDastText}
${'Coverage fuzzing'} | ${'coverageFuzzing'} | ${groupedCoverageFuzzingText}
`('grouped text for $name', ({ name, scanner, getter }) => { `('grouped text for $name', ({ name, scanner, getter }) => {
describe('with no issues', () => { describe('with no issues', () => {
it('returns no issues text', () => { it('returns no issues text', () => {
...@@ -79,9 +81,10 @@ describe('Security reports getters', () => { ...@@ -79,9 +81,10 @@ describe('Security reports getters', () => {
state.containerScanning.newIssues = [generateVuln(CRITICAL)]; state.containerScanning.newIssues = [generateVuln(CRITICAL)];
state.dast.newIssues = [generateVuln(CRITICAL)]; state.dast.newIssues = [generateVuln(CRITICAL)];
state.dependencyScanning.newIssues = [generateVuln(CRITICAL)]; state.dependencyScanning.newIssues = [generateVuln(CRITICAL)];
state.coverageFuzzing.newIssues = [generateVuln(CRITICAL)];
expect(summaryCounts(state)).toEqual({ expect(summaryCounts(state)).toEqual({
critical: 3, critical: 4,
high: 0, high: 0,
other: 0, other: 0,
}); });
...@@ -91,10 +94,11 @@ describe('Security reports getters', () => { ...@@ -91,10 +94,11 @@ describe('Security reports getters', () => {
state.containerScanning.newIssues = [generateVuln(CRITICAL)]; state.containerScanning.newIssues = [generateVuln(CRITICAL)];
state.dast.newIssues = [generateVuln(CRITICAL), generateVuln(HIGH)]; state.dast.newIssues = [generateVuln(CRITICAL), generateVuln(HIGH)];
state.dependencyScanning.newIssues = [generateVuln(LOW)]; state.dependencyScanning.newIssues = [generateVuln(LOW)];
state.coverageFuzzing.newIssues = [generateVuln(HIGH)];
expect(summaryCounts(state)).toEqual({ expect(summaryCounts(state)).toEqual({
critical: 2, critical: 2,
high: 1, high: 2,
other: 1, other: 1,
}); });
}); });
...@@ -221,6 +225,7 @@ describe('Security reports getters', () => { ...@@ -221,6 +225,7 @@ describe('Security reports getters', () => {
state.containerScanning.hasError = true; state.containerScanning.hasError = true;
state.dependencyScanning.hasError = true; state.dependencyScanning.hasError = true;
state.secretScanning.hasError = true; state.secretScanning.hasError = true;
state.coverageFuzzing.hasError = true;
expect(allReportsHaveError(state)).toEqual(true); expect(allReportsHaveError(state)).toEqual(true);
}); });
......
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