Commit 703c5542 authored by Tom Quirk's avatar Tom Quirk

Fix misleading upgrade CTA in Jira configuration

- only show Ultimate upgrade CTA when "Enable Jira issues" is checked
- remove unused/redundant computed values

Changelog: changed
parent 5695800c
...@@ -75,15 +75,6 @@ export default { ...@@ -75,15 +75,6 @@ export default {
validProjectKey() { validProjectKey() {
return !this.enableJiraIssues || Boolean(this.projectKey) || !this.validated; return !this.enableJiraIssues || Boolean(this.projectKey) || !this.validated;
}, },
showJiraVulnerabilitiesOptions() {
return this.showJiraVulnerabilitiesIntegration;
},
showUltimateUpgrade() {
return this.showJiraIssuesIntegration && !this.showJiraVulnerabilitiesIntegration;
},
showPremiumUpgrade() {
return !this.showJiraIssuesIntegration;
},
}, },
created() { created() {
eventHub.$on('validateForm', this.validateForm); eventHub.$on('validateForm', this.validateForm);
...@@ -128,23 +119,30 @@ export default { ...@@ -128,23 +119,30 @@ export default {
}} }}
</template> </template>
</gl-form-checkbox> </gl-form-checkbox>
<template v-if="enableJiraIssues">
<jira-issue-creation-vulnerabilities <jira-issue-creation-vulnerabilities
v-if="enableJiraIssues"
:project-key="projectKey" :project-key="projectKey"
:initial-is-enabled="initialEnableJiraVulnerabilities" :initial-is-enabled="initialEnableJiraVulnerabilities"
:initial-issue-type-id="initialVulnerabilitiesIssuetype" :initial-issue-type-id="initialVulnerabilitiesIssuetype"
:show-full-feature="showJiraVulnerabilitiesOptions" :show-full-feature="showJiraVulnerabilitiesIntegration"
data-testid="jira-for-vulnerabilities" data-testid="jira-for-vulnerabilities"
@request-get-issue-types="getJiraIssueTypes" @request-get-issue-types="getJiraIssueTypes"
/> />
<jira-upgrade-cta
v-if="!showJiraVulnerabilitiesIntegration"
class="gl-mt-2 gl-ml-6"
data-testid="ultimate-upgrade-cta"
show-ultimate-message
:upgrade-plan-path="upgradePlanPath"
/>
</template>
</template> </template>
<jira-upgrade-cta <jira-upgrade-cta
v-if="showUltimateUpgrade || showPremiumUpgrade" v-else
class="gl-mt-2" class="gl-mt-2"
:class="{ 'gl-ml-6': showUltimateUpgrade }" data-testid="premium-upgrade-cta"
show-premium-message
:upgrade-plan-path="upgradePlanPath" :upgrade-plan-path="upgradePlanPath"
:show-ultimate-message="showUltimateUpgrade"
:show-premium-message="showPremiumUpgrade"
/> />
</div> </div>
</gl-form-group> </gl-form-group>
......
...@@ -2,7 +2,6 @@ import { GlFormCheckbox, GlFormInput } from '@gitlab/ui'; ...@@ -2,7 +2,6 @@ import { GlFormCheckbox, GlFormInput } from '@gitlab/ui';
import { mountExtended } from 'helpers/vue_test_utils_helper'; import { mountExtended } from 'helpers/vue_test_utils_helper';
import JiraIssuesFields from '~/integrations/edit/components/jira_issues_fields.vue'; import JiraIssuesFields from '~/integrations/edit/components/jira_issues_fields.vue';
import JiraUpgradeCta from '~/integrations/edit/components/jira_upgrade_cta.vue';
import eventHub from '~/integrations/edit/event_hub'; import eventHub from '~/integrations/edit/event_hub';
import { createStore } from '~/integrations/edit/store'; import { createStore } from '~/integrations/edit/store';
...@@ -14,6 +13,7 @@ describe('JiraIssuesFields', () => { ...@@ -14,6 +13,7 @@ describe('JiraIssuesFields', () => {
editProjectPath: '/edit', editProjectPath: '/edit',
showJiraIssuesIntegration: true, showJiraIssuesIntegration: true,
showJiraVulnerabilitiesIntegration: true, showJiraVulnerabilitiesIntegration: true,
upgradePlanPath: 'https://gitlab.com',
}; };
const createComponent = ({ isInheriting = false, props, ...options } = {}) => { const createComponent = ({ isInheriting = false, props, ...options } = {}) => {
...@@ -37,47 +37,71 @@ describe('JiraIssuesFields', () => { ...@@ -37,47 +37,71 @@ describe('JiraIssuesFields', () => {
const findEnableCheckboxDisabled = () => const findEnableCheckboxDisabled = () =>
findEnableCheckbox().find('[type=checkbox]').attributes('disabled'); findEnableCheckbox().find('[type=checkbox]').attributes('disabled');
const findProjectKey = () => wrapper.findComponent(GlFormInput); const findProjectKey = () => wrapper.findComponent(GlFormInput);
const findJiraUpgradeCta = () => wrapper.findComponent(JiraUpgradeCta); const findPremiumUpgradeCTA = () => wrapper.findByTestId('premium-upgrade-cta');
const findUltimateUpgradeCTA = () => wrapper.findByTestId('ultimate-upgrade-cta');
const findJiraForVulnerabilities = () => wrapper.findByTestId('jira-for-vulnerabilities'); const findJiraForVulnerabilities = () => wrapper.findByTestId('jira-for-vulnerabilities');
const setEnableCheckbox = async (isEnabled = true) => const setEnableCheckbox = async (isEnabled = true) =>
findEnableCheckbox().vm.$emit('input', isEnabled); findEnableCheckbox().vm.$emit('input', isEnabled);
describe('jira issues call to action', () => { describe('template', () => {
it('shows the premium message', () => { describe('when `showJiraIssuesIntegration` is false', () => {
beforeEach(() => {
createComponent({ createComponent({
props: { showJiraIssuesIntegration: false }, props: { showJiraIssuesIntegration: false },
}); });
});
it('shows the premium CTA', () => {
const premiumUpgradeCTA = findPremiumUpgradeCTA();
expect(premiumUpgradeCTA.exists()).toBe(true);
expect(premiumUpgradeCTA.props('upgradePlanPath')).toBe(defaultProps.upgradePlanPath);
});
expect(findJiraUpgradeCta().props()).toMatchObject({ it('does not show checkbox and input field', () => {
showPremiumMessage: true, expect(findEnableCheckbox().exists()).toBe(false);
showUltimateMessage: false, expect(findProjectKey().exists()).toBe(false);
}); });
}); });
it('shows the ultimate message', () => { describe('when `showJiraIssuesIntegration` is true and `showJiraVulnerabilitiesIntegration` is false', () => {
beforeEach(() => {
createComponent({ createComponent({
props: { props: { showJiraIssuesIntegration: true, showJiraVulnerabilitiesIntegration: false },
showJiraIssuesIntegration: true, });
showJiraVulnerabilitiesIntegration: false, });
},
it('renders "Enable Jira Issues" checkbox', () => {
expect(findEnableCheckbox().exists()).toBe(true);
expect(findEnableCheckboxDisabled()).toBeUndefined();
}); });
expect(findJiraUpgradeCta().props()).toMatchObject({ it.each`
showPremiumMessage: false, scenario | enableJiraIssues
showUltimateMessage: true, ${'when "Enable Jira Issues" is checked, shows ultimate upgrade CTA'} | ${true}
${'when "Enable Jira Issues" is unchecked, does not show ultimate upgrade CTA'} | ${false}
`('$scenario', async ({ enableJiraIssues }) => {
createComponent({
props: { showJiraIssuesIntegration: true, showJiraVulnerabilitiesIntegration: false },
}); });
if (enableJiraIssues) {
await setEnableCheckbox();
}
expect(findPremiumUpgradeCTA().exists()).toBe(false);
expect(findUltimateUpgradeCTA().exists()).toBe(enableJiraIssues);
}); });
}); });
describe('template', () => { describe('when `showJiraIssuesIntegration` is true and `showJiraVulnerabilitiesIntegration` is true', () => {
describe('upgrade banner for non-Premium user', () => { it('does not show any upgrade CTA', () => {
beforeEach(() => { createComponent({
createComponent({ props: { initialProjectKey: '', showJiraIssuesIntegration: false } }); props: { showJiraIssuesIntegration: true, showJiraVulnerabilitiesIntegration: true },
}); });
it('does not show checkbox and input field', () => { expect(findPremiumUpgradeCTA().exists()).toBe(false);
expect(findEnableCheckbox().exists()).toBe(false); expect(findUltimateUpgradeCTA().exists()).toBe(false);
expect(findProjectKey().exists()).toBe(false);
}); });
}); });
...@@ -86,11 +110,6 @@ describe('JiraIssuesFields', () => { ...@@ -86,11 +110,6 @@ describe('JiraIssuesFields', () => {
createComponent({ props: { initialProjectKey: '' } }); createComponent({ props: { initialProjectKey: '' } });
}); });
it('renders enabled checkbox', () => {
expect(findEnableCheckbox().exists()).toBe(true);
expect(findEnableCheckboxDisabled()).toBeUndefined();
});
it('renders disabled project_key input', () => { it('renders disabled project_key input', () => {
const projectKey = findProjectKey(); const projectKey = findProjectKey();
...@@ -99,10 +118,6 @@ describe('JiraIssuesFields', () => { ...@@ -99,10 +118,6 @@ describe('JiraIssuesFields', () => {
expect(projectKey.attributes('required')).toBeUndefined(); expect(projectKey.attributes('required')).toBeUndefined();
}); });
it('does not show upgrade banner', () => {
expect(findJiraUpgradeCta().exists()).toBe(false);
});
// As per https://vuejs.org/v2/guide/forms.html#Checkbox-1, // As per https://vuejs.org/v2/guide/forms.html#Checkbox-1,
// browsers don't include unchecked boxes in form submissions. // browsers don't include unchecked boxes in form submissions.
it('includes issues_enabled as false even if unchecked', () => { it('includes issues_enabled as false even if unchecked', () => {
......
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