Commit e32b1107 authored by Dave Pisek's avatar Dave Pisek

Show create-jira on pipeline and MR when enabled

This commit fixes an issue that prevents the create-jira-issue
button from displaying on the security MR-widget and pipeline modal
when GitLab-issues are disabled.

Changelog: fixed
EE: true
MR: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/68821
parent 49046fe3
...@@ -66,8 +66,12 @@ export default { ...@@ -66,8 +66,12 @@ export default {
return Boolean(path); return Boolean(path);
}, },
canCreateIssue() { canCreateIssue() {
const path = this.vulnerability.create_vulnerability_feedback_issue_path; const {
return Boolean(path) && !this.hasIssue; create_vulnerability_feedback_issue_path: createGitLabIssuePath,
create_jira_issue_url: createJiraIssueUrl,
} = this.vulnerability;
return Boolean(createGitLabIssuePath || createJiraIssueUrl) && !this.hasIssue;
}, },
extraIdentifierCount() { extraIdentifierCount() {
const { identifiers } = this.vulnerability; const { identifiers } = this.vulnerability;
......
...@@ -62,7 +62,10 @@ export const coverageFuzzingStatusIcon = ({ coverageFuzzing }) => ...@@ -62,7 +62,10 @@ export const coverageFuzzingStatusIcon = ({ coverageFuzzing }) =>
export const isBaseSecurityReportOutOfDate = (state) => export const isBaseSecurityReportOutOfDate = (state) =>
state.reportTypes.some((reportType) => state[reportType].baseReportOutofDate); state.reportTypes.some((reportType) => state[reportType].baseReportOutofDate);
export const canCreateIssue = (state) => Boolean(state.createVulnerabilityFeedbackIssuePath); export const canCreateIssue = (state) =>
Boolean(
state.createVulnerabilityFeedbackIssuePath || state.modal?.vulnerability?.create_jira_issue_url,
);
export const canCreateMergeRequest = (state) => export const canCreateMergeRequest = (state) =>
Boolean(state.createVulnerabilityFeedbackMergeRequestPath); Boolean(state.createVulnerabilityFeedbackMergeRequestPath);
......
...@@ -2,6 +2,7 @@ import { GlFormCheckbox } from '@gitlab/ui'; ...@@ -2,6 +2,7 @@ import { GlFormCheckbox } from '@gitlab/ui';
import { mount, shallowMount, createLocalVue } from '@vue/test-utils'; import { mount, shallowMount, createLocalVue } from '@vue/test-utils';
import Vuex from 'vuex'; import Vuex from 'vuex';
import SecurityDashboardTableRow from 'ee/security_dashboard/components/pipeline/security_dashboard_table_row.vue'; import SecurityDashboardTableRow from 'ee/security_dashboard/components/pipeline/security_dashboard_table_row.vue';
import VulnerabilityActionButtons from 'ee/security_dashboard/components/pipeline/vulnerability_action_buttons.vue';
import createStore from 'ee/security_dashboard/store'; import createStore from 'ee/security_dashboard/store';
import { DASHBOARD_TYPES } from 'ee/security_dashboard/store/constants'; import { DASHBOARD_TYPES } from 'ee/security_dashboard/store/constants';
import { VULNERABILITY_MODAL_ID } from 'ee/vue_shared/security_reports/components/constants'; import { VULNERABILITY_MODAL_ID } from 'ee/vue_shared/security_reports/components/constants';
...@@ -254,4 +255,29 @@ describe('Security Dashboard Table Row', () => { ...@@ -254,4 +255,29 @@ describe('Security Dashboard Table Row', () => {
expect(findContent(2).text()).toBe(identifiers[0].name); expect(findContent(2).text()).toBe(identifiers[0].name);
}); });
}); });
describe.each`
createGitLabIssuePath | createJiraIssueUrl | canCreateIssue
${''} | ${''} | ${false}
${''} | ${'http://foo.bar'} | ${true}
${'/foo/bar'} | ${''} | ${true}
${'/foo/bar'} | ${'http://foo.bar'} | ${true}
`(
'with createGitLabIssuePath set to "$createGitLabIssuePath" and createJiraIssueUrl to "$createJiraIssueUrl"',
({ createGitLabIssuePath, createJiraIssueUrl, canCreateIssue }) => {
beforeEach(() => {
const vulnerability = mockDataVulnerabilities[1];
vulnerability.create_vulnerability_feedback_issue_path = createGitLabIssuePath;
vulnerability.create_jira_issue_url = createJiraIssueUrl;
createComponent(shallowMount, { props: { vulnerability } });
});
it(`should pass "canCreateIssue" as "${canCreateIssue}" to the action-buttons component`, () => {
expect(wrapper.findComponent(VulnerabilityActionButtons).props('canCreateIssue')).toBe(
canCreateIssue,
);
});
},
);
}); });
...@@ -304,15 +304,25 @@ describe('Security reports getters', () => { ...@@ -304,15 +304,25 @@ describe('Security reports getters', () => {
}); });
describe('canCreateIssue', () => { describe('canCreateIssue', () => {
it('returns false if no feedback path is defined', () => { it.each`
expect(canCreateIssue(state)).toEqual(false); createVulnerabilityFeedbackIssuePath | createJiraIssueUrl | expectedReturnValue
}); ${''} | ${''} | ${false}
${'/foo/bar'} | ${''} | ${true}
it('returns true if a feedback path is defined', () => { ${''} | ${'http://foo.bar'} | ${true}
state.createVulnerabilityFeedbackIssuePath = MOCK_PATH; ${'/foo/bar'} | ${'http://foo.bar'} | ${true}
`(
expect(canCreateIssue(state)).toEqual(true); 'returns "$expectedReturnValue" with createVulnerabilityFeedbackIssuePath set to "createVulnerabilityFeedbackIssuePath" and modal.vulnerability.create_jira_issue_url to "$createJiraIssueUrl"',
}); ({ createVulnerabilityFeedbackIssuePath, createJiraIssueUrl, expectedReturnValue }) => {
state.createVulnerabilityFeedbackIssuePath = createVulnerabilityFeedbackIssuePath;
state.modal = {
vulnerability: {
create_jira_issue_url: createJiraIssueUrl,
},
};
expect(canCreateIssue(state)).toEqual(expectedReturnValue);
},
);
}); });
describe('canCreateMergeRequest', () => { describe('canCreateMergeRequest', () => {
......
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