Commit e3419771 authored by Kushal Pandya's avatar Kushal Pandya

Merge branch 'remove-confidence-labels' into 'master'

Frontend: Remove confidence from security reports

See merge request gitlab-org/gitlab!24033
parents e767eb5b f864615f
...@@ -49,9 +49,6 @@ export default { ...@@ -49,9 +49,6 @@ export default {
role="row" role="row"
> >
<div class="table-section section-10" role="rowheader">{{ s__('Reports|Severity') }}</div> <div class="table-section section-10" role="rowheader">{{ s__('Reports|Severity') }}</div>
<div class="table-section section-10 ml-md-2" role="rowheader">
{{ s__('Reports|Confidence') }}
</div>
<div class="table-section flex-grow-1" role="rowheader"> <div class="table-section flex-grow-1" role="rowheader">
{{ s__('Reports|Vulnerability') }} {{ s__('Reports|Vulnerability') }}
</div> </div>
......
...@@ -30,9 +30,6 @@ export default { ...@@ -30,9 +30,6 @@ export default {
}, },
}, },
computed: { computed: {
confidence() {
return this.vulnerability.confidence || '';
},
severity() { severity() {
return this.vulnerability.severity || ' '; return this.vulnerability.severity || ' ';
}, },
...@@ -74,11 +71,6 @@ export default { ...@@ -74,11 +71,6 @@ export default {
<div class="table-mobile-content"><severity-badge :severity="severity" /></div> <div class="table-mobile-content"><severity-badge :severity="severity" /></div>
</div> </div>
<div class="table-section section-10 ml-md-2">
<div class="table-mobile-header" role="rowheader">{{ s__('Reports|Confidence') }}</div>
<div class="table-mobile-content text-capitalize">{{ confidence }}</div>
</div>
<div class="table-section flex-grow-1"> <div class="table-section flex-grow-1">
<div class="table-mobile-header" role="rowheader">{{ s__('Reports|Vulnerability') }}</div> <div class="table-mobile-header" role="rowheader">{{ s__('Reports|Vulnerability') }}</div>
<div <div
......
...@@ -11,17 +11,6 @@ export const SEVERITY_LEVELS = { ...@@ -11,17 +11,6 @@ export const SEVERITY_LEVELS = {
none: s__('severity|None'), none: s__('severity|None'),
}; };
export const CONFIDENCE_LEVELS = {
confirmed: s__('confidence|Confirmed'),
high: s__('confidence|High'),
medium: s__('confidence|Medium'),
low: s__('confidence|Low'),
unknown: s__('confidence|Unknown'),
ignore: s__('confidence|Ignore'),
experimental: s__('confidence|Experimental'),
undefined: s__('confidence|Undefined'),
};
export const REPORT_TYPES = { export const REPORT_TYPES = {
container_scanning: s__('ciReport|Container Scanning'), container_scanning: s__('ciReport|Container Scanning'),
dast: s__('ciReport|DAST'), dast: s__('ciReport|DAST'),
......
...@@ -10,17 +10,6 @@ export const SEVERITY_LEVELS = { ...@@ -10,17 +10,6 @@ export const SEVERITY_LEVELS = {
undefined: s__('severity|Undefined'), undefined: s__('severity|Undefined'),
}; };
export const CONFIDENCE_LEVELS = {
confirmed: s__('confidence|Confirmed'),
high: s__('confidence|High'),
medium: s__('confidence|Medium'),
low: s__('confidence|Low'),
unknown: s__('confidence|Unknown'),
ignore: s__('confidence|Ignore'),
experimental: s__('confidence|Experimental'),
undefined: s__('confidence|Undefined'),
};
export const REPORT_TYPES = { export const REPORT_TYPES = {
container_scanning: s__('ciReport|Container Scanning'), container_scanning: s__('ciReport|Container Scanning'),
dast: s__('ciReport|DAST'), dast: s__('ciReport|DAST'),
...@@ -34,10 +23,6 @@ export const BASE_FILTERS = { ...@@ -34,10 +23,6 @@ export const BASE_FILTERS = {
name: s__('ciReport|All severities'), name: s__('ciReport|All severities'),
id: ALL, id: ALL,
}, },
confidence: {
name: s__('ciReport|All confidence levels'),
id: ALL,
},
report_type: { report_type: {
name: s__('ciReport|All report types'), name: s__('ciReport|All report types'),
id: ALL, id: ALL,
......
import { SEVERITY_LEVELS, CONFIDENCE_LEVELS, REPORT_TYPES, BASE_FILTERS } from './constants'; import { SEVERITY_LEVELS, REPORT_TYPES, BASE_FILTERS } from './constants';
import { s__ } from '~/locale'; import { s__ } from '~/locale';
const optionsObjectToArray = obj => Object.entries(obj).map(([id, name]) => ({ id, name })); const optionsObjectToArray = obj => Object.entries(obj).map(([id, name]) => ({ id, name }));
...@@ -12,13 +12,6 @@ export default () => ({ ...@@ -12,13 +12,6 @@ export default () => ({
hidden: false, hidden: false,
selection: new Set([BASE_FILTERS.severity.id]), selection: new Set([BASE_FILTERS.severity.id]),
}, },
{
name: s__('SecurityDashboard|Confidence'),
id: 'confidence',
options: [BASE_FILTERS.confidence, ...optionsObjectToArray(CONFIDENCE_LEVELS)],
hidden: false,
selection: new Set([BASE_FILTERS.confidence.id]),
},
{ {
name: s__('SecurityDashboard|Report type'), name: s__('SecurityDashboard|Report type'),
id: 'report_type', id: 'report_type',
......
...@@ -124,7 +124,6 @@ export default { ...@@ -124,7 +124,6 @@ export default {
Vue.set(state.modal.data.severity, 'value', vulnerability.severity); Vue.set(state.modal.data.severity, 'value', vulnerability.severity);
Vue.set(state.modal.data.reportType, 'value', vulnerability.report_type); Vue.set(state.modal.data.reportType, 'value', vulnerability.report_type);
Vue.set(state.modal.data.confidence, 'value', vulnerability.confidence);
Vue.set(state.modal, 'vulnerability', vulnerability); Vue.set(state.modal, 'vulnerability', vulnerability);
Vue.set( Vue.set(
state.modal.vulnerability, state.modal.vulnerability,
......
...@@ -30,7 +30,6 @@ export default () => ({ ...@@ -30,7 +30,6 @@ export default () => ({
file: { text: s__('Vulnerability|File') }, file: { text: s__('Vulnerability|File') },
identifiers: { text: s__('Vulnerability|Identifiers') }, identifiers: { text: s__('Vulnerability|Identifiers') },
severity: { text: s__('Vulnerability|Severity') }, severity: { text: s__('Vulnerability|Severity') },
confidence: { text: s__('Vulnerability|Confidence') },
reportType: { text: s__('Vulnerability|Report Type') }, reportType: { text: s__('Vulnerability|Report Type') },
className: { text: s__('Vulnerability|Class') }, className: { text: s__('Vulnerability|Class') },
image: { text: s__('Vulnerability|Image') }, image: { text: s__('Vulnerability|Image') },
......
<script> <script>
/** /**
* Renders DAST body text * Renders DAST body text
* [severity] ([confidence]): [name] * [severity]: [name]
*/ */
import ModalOpenName from '~/reports/components/modal_open_name.vue'; import ModalOpenName from '~/reports/components/modal_open_name.vue';
...@@ -27,7 +27,7 @@ export default { ...@@ -27,7 +27,7 @@ export default {
<template> <template>
<div class="report-block-list-issue-description prepend-top-5 append-bottom-5"> <div class="report-block-list-issue-description prepend-top-5 append-bottom-5">
<div class="report-block-list-issue-description-text"> <div class="report-block-list-issue-description-text">
{{ issue.severity }} ({{ issue.confidence }}): {{ issue.severity }}:
<modal-open-name :issue="issue" :status="status" class="js-modal-dast" /> <modal-open-name :issue="issue" :status="status" class="js-modal-dast" />
</div> </div>
......
<script> <script>
/** /**
* Renders SAST body text * Renders SAST body text
* [severity] ([confidence]): [name] in [link] : [line] * [severity]: [name] in [link] : [line]
*/ */
import ReportLink from '~/reports/components/report_link.vue'; import ReportLink from '~/reports/components/report_link.vue';
import ModalOpenName from '~/reports/components/modal_open_name.vue'; import ModalOpenName from '~/reports/components/modal_open_name.vue';
...@@ -29,17 +29,10 @@ export default { ...@@ -29,17 +29,10 @@ export default {
computed: { computed: {
title() { title() {
const { severity, confidence, priority } = this.issue; const { severity, priority } = this.issue;
if (severity) { if (severity) {
if (confidence) {
return `${humanize(severity)} (${humanize(confidence)})`;
}
return humanize(severity); return humanize(severity);
} else if (confidence) {
return `(${humanize(confidence)})`;
} }
return priority; return priority;
}, },
}, },
......
...@@ -119,11 +119,7 @@ export default { ...@@ -119,11 +119,7 @@ export default {
> >
<gl-friendly-wrap :text="field.value" /> <gl-friendly-wrap :text="field.value" />
</safe-link> </safe-link>
<gl-friendly-wrap <gl-friendly-wrap v-else :text="field.value" />
v-else
:text="field.value"
:class="{ 'text-capitalize': key === 'confidence' }"
/>
</template> </template>
</template> </template>
</div> </div>
......
...@@ -155,7 +155,6 @@ export default { ...@@ -155,7 +155,6 @@ export default {
} }
Vue.set(state.modal.data.severity, 'value', issue.severity); Vue.set(state.modal.data.severity, 'value', issue.severity);
Vue.set(state.modal.data.confidence, 'value', issue.confidence);
if (issue.links && issue.links.length > 0) { if (issue.links && issue.links.length > 0) {
Vue.set(state.modal.data.links, 'value', issue.links); Vue.set(state.modal.data.links, 'value', issue.links);
......
...@@ -96,11 +96,6 @@ export default () => ({ ...@@ -96,11 +96,6 @@ export default () => ({
text: s__('ciReport|Severity'), text: s__('ciReport|Severity'),
isLink: false, isLink: false,
}, },
confidence: {
value: null,
text: s__('ciReport|Confidence'),
isLink: false,
},
className: { className: {
value: null, value: null,
text: s__('ciReport|Class'), text: s__('ciReport|Class'),
......
---
title: Remove confidence labels from security report
merge_request: 24033
author:
type: removed
...@@ -8,7 +8,7 @@ exports[`Dast Issue Body matches the snaphot 1`] = ` ...@@ -8,7 +8,7 @@ exports[`Dast Issue Body matches the snaphot 1`] = `
class="report-block-list-issue-description-text" class="report-block-list-issue-description-text"
> >
Low (Medium): Low:
<modal-open-name-stub <modal-open-name-stub
......
...@@ -8,7 +8,7 @@ exports[`Sast Issue Body matches snapshot 1`] = ` ...@@ -8,7 +8,7 @@ exports[`Sast Issue Body matches snapshot 1`] = `
class="report-block-list-issue-description-text" class="report-block-list-issue-description-text"
> >
Medium (Low): Medium:
<modal-open-name-stub <modal-open-name-stub
issue="[object Object]" issue="[object Object]"
......
...@@ -10,7 +10,6 @@ describe('Dast Issue Body', () => { ...@@ -10,7 +10,6 @@ describe('Dast Issue Body', () => {
issue: { issue: {
alert: 'X-Content-Type-Options Header Missing', alert: 'X-Content-Type-Options Header Missing',
severity: 'Low', severity: 'Low',
confidence: 'Medium',
count: '17', count: '17',
cweid: '16', cweid: '16',
desc: desc:
......
...@@ -26,14 +26,13 @@ describe('Sast Issue Body', () => { ...@@ -26,14 +26,13 @@ describe('Sast Issue Body', () => {
it('matches snapshot', () => { it('matches snapshot', () => {
createComponent({ createComponent({
severity: 'medium', severity: 'medium',
confidence: 'low',
priority: 'high', priority: 'high',
}); });
expect(wrapper.element).toMatchSnapshot(); expect(wrapper.element).toMatchSnapshot();
}); });
it('renders priority if no security and confidence are passed', () => { it('renders priority if no security are passed', () => {
createComponent({ createComponent({
priority: 'high', priority: 'high',
}); });
...@@ -41,15 +40,7 @@ describe('Sast Issue Body', () => { ...@@ -41,15 +40,7 @@ describe('Sast Issue Body', () => {
expect(findDescriptionText().text()).toBe('high:'); expect(findDescriptionText().text()).toBe('high:');
}); });
it('renders confidence if no severity is passed', () => { it('renders severity', () => {
createComponent({
confidence: 'low',
});
expect(findDescriptionText().text()).toBe('(Low):');
});
it('renders severity if no confidence is passed', () => {
createComponent({ createComponent({
severity: 'medium', severity: 'medium',
}); });
...@@ -57,15 +48,6 @@ describe('Sast Issue Body', () => { ...@@ -57,15 +48,6 @@ describe('Sast Issue Body', () => {
expect(findDescriptionText().text()).toBe('Medium:'); expect(findDescriptionText().text()).toBe('Medium:');
}); });
it('renders severity and confidence if both are passed', () => {
createComponent({
severity: 'medium',
confidence: 'low',
});
expect(findDescriptionText().text()).toBe('Medium (Low):');
});
it('does not render report link if no path is passed', () => { it('does not render report link if no path is passed', () => {
createComponent({}); createComponent({});
......
...@@ -118,7 +118,6 @@ export const parsedDast = [ ...@@ -118,7 +118,6 @@ export const parsedDast = [
riskcode: '1', riskcode: '1',
riskdesc: 'Low (Medium)', riskdesc: 'Low (Medium)',
severity: 'Low', severity: 'Low',
confidence: 'Medium',
cweid: '3', cweid: '3',
desc: '<p>No Anti-CSRF tokens were found in a HTML submission form.</p>', desc: '<p>No Anti-CSRF tokens were found in a HTML submission form.</p>',
pluginid: '123', pluginid: '123',
...@@ -161,7 +160,6 @@ export const parsedDast = [ ...@@ -161,7 +160,6 @@ export const parsedDast = [
}, },
], ],
severity: 'Low', severity: 'Low',
confidence: 'Medium',
cweid: '4', cweid: '4',
desc: '<p>The Anti-MIME-Sniffing header X-Content-Type-Options was not set to "nosniff".</p>', desc: '<p>The Anti-MIME-Sniffing header X-Content-Type-Options was not set to "nosniff".</p>',
pluginid: '3456', pluginid: '3456',
...@@ -258,7 +256,6 @@ export const mockFindings = [ ...@@ -258,7 +256,6 @@ export const mockFindings = [
report_type: 'dependency_scanning', report_type: 'dependency_scanning',
name: 'Cross-site Scripting in serialize-javascript', name: 'Cross-site Scripting in serialize-javascript',
severity: 'unknown', severity: 'unknown',
confidence: 'undefined',
scanner: { external_id: 'gemnasium', name: 'Gemnasium' }, scanner: { external_id: 'gemnasium', name: 'Gemnasium' },
identifiers: [ identifiers: [
{ {
...@@ -306,7 +303,6 @@ export const mockFindings = [ ...@@ -306,7 +303,6 @@ export const mockFindings = [
report_type: 'dependency_scanning', report_type: 'dependency_scanning',
name: '3rd party CORS request may execute in jquery', name: '3rd party CORS request may execute in jquery',
severity: 'medium', severity: 'medium',
confidence: 'undefined',
scanner: { external_id: 'retire.js', name: 'Retire.js' }, scanner: { external_id: 'retire.js', name: 'Retire.js' },
identifiers: [ identifiers: [
{ {
...@@ -390,7 +386,6 @@ export const mockFindings = [ ...@@ -390,7 +386,6 @@ export const mockFindings = [
name: name:
'jQuery before 3.4.0, as used in Drupal, Backdrop CMS, and other products, mishandles jQuery.extend(true, {}, ...) because of Object.prototype pollution in jquery', 'jQuery before 3.4.0, as used in Drupal, Backdrop CMS, and other products, mishandles jQuery.extend(true, {}, ...) because of Object.prototype pollution in jquery',
severity: 'low', severity: 'low',
confidence: 'undefined',
scanner: { external_id: 'retire.js', name: 'Retire.js' }, scanner: { external_id: 'retire.js', name: 'Retire.js' },
identifiers: [ identifiers: [
{ {
...@@ -473,7 +468,6 @@ export const mockFindings = [ ...@@ -473,7 +468,6 @@ export const mockFindings = [
name: name:
'jQuery before 3.4.0, as used in Drupal, Backdrop CMS, and other products, mishandles jQuery.extend(true, {}, ...) because of Object.prototype pollution in jquery', 'jQuery before 3.4.0, as used in Drupal, Backdrop CMS, and other products, mishandles jQuery.extend(true, {}, ...) because of Object.prototype pollution in jquery',
severity: 'low', severity: 'low',
confidence: 'undefined',
scanner: { external_id: 'retire.js', name: 'Retire.js' }, scanner: { external_id: 'retire.js', name: 'Retire.js' },
identifiers: [ identifiers: [
{ {
......
...@@ -125,10 +125,6 @@ describe('security reports mutations', () => { ...@@ -125,10 +125,6 @@ describe('security reports mutations', () => {
expect(stateCopy.modal.data.severity.text).toEqual('Severity'); expect(stateCopy.modal.data.severity.text).toEqual('Severity');
expect(stateCopy.modal.data.severity.isLink).toEqual(false); expect(stateCopy.modal.data.severity.isLink).toEqual(false);
expect(stateCopy.modal.data.confidence.value).toEqual(null);
expect(stateCopy.modal.data.confidence.text).toEqual('Confidence');
expect(stateCopy.modal.data.confidence.isLink).toEqual(false);
expect(stateCopy.modal.data.links.value).toEqual([]); expect(stateCopy.modal.data.links.value).toEqual([]);
expect(stateCopy.modal.data.links.text).toEqual('Links'); expect(stateCopy.modal.data.links.text).toEqual('Links');
expect(stateCopy.modal.data.links.isLink).toEqual(false); expect(stateCopy.modal.data.links.isLink).toEqual(false);
...@@ -207,7 +203,6 @@ describe('security reports mutations', () => { ...@@ -207,7 +203,6 @@ describe('security reports mutations', () => {
expect(stateCopy.modal.data.image.value).toEqual(issue.location.image); expect(stateCopy.modal.data.image.value).toEqual(issue.location.image);
expect(stateCopy.modal.data.identifiers.value).toEqual(issue.identifiers); expect(stateCopy.modal.data.identifiers.value).toEqual(issue.identifiers);
expect(stateCopy.modal.data.severity.value).toEqual(issue.severity); expect(stateCopy.modal.data.severity.value).toEqual(issue.severity);
expect(stateCopy.modal.data.confidence.value).toEqual(issue.confidence);
expect(stateCopy.modal.data.links.value).toEqual(issue.links); expect(stateCopy.modal.data.links.value).toEqual(issue.links);
expect(stateCopy.modal.data.instances.value).toEqual(issue.instances); expect(stateCopy.modal.data.instances.value).toEqual(issue.instances);
expect(stateCopy.modal.data.url.value).toEqual( expect(stateCopy.modal.data.url.value).toEqual(
......
...@@ -18,7 +18,7 @@ describe('Filter component', () => { ...@@ -18,7 +18,7 @@ describe('Filter component', () => {
}); });
it('should display all filters', () => { it('should display all filters', () => {
expect(vm.$el.querySelectorAll('.js-filter').length).toEqual(4); expect(vm.$el.querySelectorAll('.js-filter').length).toEqual(3);
}); });
it('should display "Hide dismissed vulnerabilities" toggle', () => { it('should display "Hide dismissed vulnerabilities" toggle', () => {
......
...@@ -30,11 +30,6 @@ describe('Security Dashboard Table Row', () => { ...@@ -30,11 +30,6 @@ describe('Security Dashboard Table Row', () => {
expect(vm.$el.querySelectorAll('.table-mobile-content')[0].textContent).toContain(' '); expect(vm.$el.querySelectorAll('.table-mobile-content')[0].textContent).toContain(' ');
}); });
it('should render a `–` for confidence', () => {
expect(vm.confidence).toEqual('');
expect(vm.$el.querySelectorAll('.table-mobile-content')[1].textContent).toContain('');
});
it('should not render action buttons', () => { it('should not render action buttons', () => {
expect(vm.$el.querySelectorAll('.action-buttons button').length).toBe(0); expect(vm.$el.querySelectorAll('.action-buttons button').length).toBe(0);
}); });
...@@ -62,21 +57,15 @@ describe('Security Dashboard Table Row', () => { ...@@ -62,21 +57,15 @@ describe('Security Dashboard Table Row', () => {
).toContain(props.vulnerability.severity); ).toContain(props.vulnerability.severity);
}); });
it('should render the confidence', () => {
expect(
vm.$el.querySelectorAll('.table-mobile-content')[1].textContent.toLowerCase(),
).toContain(props.vulnerability.confidence);
});
describe('the project name', () => { describe('the project name', () => {
it('should render the name', () => { it('should render the name', () => {
expect(vm.$el.querySelectorAll('.table-mobile-content')[2].textContent).toContain( expect(vm.$el.querySelectorAll('.table-mobile-content')[1].textContent).toContain(
props.vulnerability.name, props.vulnerability.name,
); );
}); });
it('should render the project namespace', () => { it('should render the project namespace', () => {
expect(vm.$el.querySelectorAll('.table-mobile-content')[2].textContent).toContain( expect(vm.$el.querySelectorAll('.table-mobile-content')[1].textContent).toContain(
props.vulnerability.location.file, props.vulnerability.location.file,
); );
}); });
...@@ -106,7 +95,7 @@ describe('Security Dashboard Table Row', () => { ...@@ -106,7 +95,7 @@ describe('Security Dashboard Table Row', () => {
}); });
it('should contain project name as the namespace', () => { it('should contain project name as the namespace', () => {
expect(vm.$el.querySelectorAll('.table-mobile-content')[2].textContent).toContain( expect(vm.$el.querySelectorAll('.table-mobile-content')[1].textContent).toContain(
props.vulnerability.project.full_name, props.vulnerability.project.full_name,
); );
}); });
...@@ -126,7 +115,7 @@ describe('Security Dashboard Table Row', () => { ...@@ -126,7 +115,7 @@ describe('Security Dashboard Table Row', () => {
}); });
it('should contain container image as the namespace', () => { it('should contain container image as the namespace', () => {
expect(vm.$el.querySelectorAll('.table-mobile-content')[2].textContent).toContain( expect(vm.$el.querySelectorAll('.table-mobile-content')[1].textContent).toContain(
props.vulnerability.location.image, props.vulnerability.location.image,
); );
}); });
......
...@@ -266,10 +266,6 @@ describe('vulnerabilities module mutations', () => { ...@@ -266,10 +266,6 @@ describe('vulnerabilities module mutations', () => {
expect(state.modal.data.severity.value).toEqual(vulnerability.severity); expect(state.modal.data.severity.value).toEqual(vulnerability.severity);
}); });
it('should set the modal confidence', () => {
expect(state.modal.data.confidence.value).toEqual(vulnerability.confidence);
});
it('should set the modal class', () => { it('should set the modal class', () => {
expect(state.modal.data.className.value).toEqual(vulnerability.location.class); expect(state.modal.data.className.value).toEqual(vulnerability.location.class);
}); });
......
...@@ -118,11 +118,9 @@ describe('Report issues', () => { ...@@ -118,11 +118,9 @@ describe('Report issues', () => {
}); });
}); });
it('renders severity (confidence) and title', () => { it('renders severity and title', () => {
expect(vm.$el.textContent).toContain(parsedDast[0].title); expect(vm.$el.textContent).toContain(parsedDast[0].title);
expect(vm.$el.textContent).toContain( expect(vm.$el.textContent).toContain(`${parsedDast[0].severity}`);
`${parsedDast[0].severity} (${parsedDast[0].confidence})`,
);
}); });
}); });
}); });
...@@ -118,11 +118,9 @@ describe('Report issue', () => { ...@@ -118,11 +118,9 @@ describe('Report issue', () => {
}); });
}); });
it('renders severity (confidence) and title', () => { it('renders severity and title', () => {
expect(vm.$el.textContent).toContain(parsedDast[0].title); expect(vm.$el.textContent).toContain(parsedDast[0].title);
expect(vm.$el.textContent).toContain( expect(vm.$el.textContent).toContain(`${parsedDast[0].severity}`);
`${parsedDast[0].severity} (${parsedDast[0].confidence})`,
);
}); });
}); });
......
...@@ -15962,9 +15962,6 @@ msgstr "" ...@@ -15962,9 +15962,6 @@ msgstr ""
msgid "Reports|Classname" msgid "Reports|Classname"
msgstr "" msgstr ""
msgid "Reports|Confidence"
msgstr ""
msgid "Reports|Execution time" msgid "Reports|Execution time"
msgstr "" msgstr ""
...@@ -16827,9 +16824,6 @@ msgstr "" ...@@ -16827,9 +16824,6 @@ msgstr ""
msgid "SecurityDashboard|Add projects" msgid "SecurityDashboard|Add projects"
msgstr "" msgstr ""
msgid "SecurityDashboard|Confidence"
msgstr ""
msgid "SecurityDashboard|Edit dashboard" msgid "SecurityDashboard|Edit dashboard"
msgstr "" msgstr ""
...@@ -21318,9 +21312,6 @@ msgstr "" ...@@ -21318,9 +21312,6 @@ msgstr ""
msgid "Vulnerability|Class" msgid "Vulnerability|Class"
msgstr "" msgstr ""
msgid "Vulnerability|Confidence"
msgstr ""
msgid "Vulnerability|Description" msgid "Vulnerability|Description"
msgstr "" msgstr ""
...@@ -22406,9 +22397,6 @@ msgstr "" ...@@ -22406,9 +22397,6 @@ msgstr ""
msgid "ciReport|(is loading, errors when loading results)" msgid "ciReport|(is loading, errors when loading results)"
msgstr "" msgstr ""
msgid "ciReport|All confidence levels"
msgstr ""
msgid "ciReport|All projects" msgid "ciReport|All projects"
msgstr "" msgstr ""
...@@ -22430,9 +22418,6 @@ msgstr "" ...@@ -22430,9 +22418,6 @@ msgstr ""
msgid "ciReport|Code quality" msgid "ciReport|Code quality"
msgstr "" msgstr ""
msgid "ciReport|Confidence"
msgstr ""
msgid "ciReport|Container Scanning" msgid "ciReport|Container Scanning"
msgstr "" msgstr ""
...@@ -22570,30 +22555,6 @@ msgstr "" ...@@ -22570,30 +22555,6 @@ msgstr ""
msgid "commit %{commit_id}" msgid "commit %{commit_id}"
msgstr "" msgstr ""
msgid "confidence|Confirmed"
msgstr ""
msgid "confidence|Experimental"
msgstr ""
msgid "confidence|High"
msgstr ""
msgid "confidence|Ignore"
msgstr ""
msgid "confidence|Low"
msgstr ""
msgid "confidence|Medium"
msgstr ""
msgid "confidence|Undefined"
msgstr ""
msgid "confidence|Unknown"
msgstr ""
msgid "confidentiality|You are going to turn off the confidentiality. This means <strong>everyone</strong> will be able to see and leave a comment on this issue." msgid "confidentiality|You are going to turn off the confidentiality. This means <strong>everyone</strong> will be able to see and leave a comment on this issue."
msgstr "" msgstr ""
......
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