Commit e4161296 authored by Phil Hughes's avatar Phil Hughes

Merge branch 'ag-331229-checkbox-state' into 'master'

Fix checkbox state during navigation

See merge request gitlab-org/gitlab!64399
parents dc8118fb 5131059f
......@@ -23,7 +23,7 @@ export const SUBSCRIPTION_ACTIVATION_FAILURE_EVENT = 'subscription-activation-fa
export const SUBSCRIPTION_ACTIVATION_SUCCESS_EVENT = 'subscription-activation-success';
export default {
name: 'CloudLicenseSubscriptionActivationForm',
name: 'SubscriptionActivationForm',
components: {
GlButton,
GlForm,
......@@ -64,6 +64,7 @@ export default {
terms: {
required: true,
state: null,
value: null,
},
},
};
......@@ -73,12 +74,6 @@ export default {
};
},
computed: {
isCheckboxValid() {
if (this.form.showValidation) {
return this.form.fields.terms.state ? null : false;
}
return null;
},
isRequestingActivation() {
return this.isLoading;
},
......@@ -149,15 +144,18 @@ export default {
<gl-form-group
class="gl-mb-0"
:state="isCheckboxValid"
:invalid-feedback="$options.i18n.fieldRequiredMessage"
data-testid="form-group-terms"
>
<gl-form-checkbox
id="subscription-form-terms-check"
v-model="form.fields.terms.state"
:state="isCheckboxValid"
v-model="form.fields.terms.value"
v-validation:[form.showValidation]
:state="form.fields.terms.state"
name="terms"
required
>
<span class="gl-text-gray-900!">
<gl-sprintf :message="$options.i18n.acceptTerms">
<template #link="{ content }">
<gl-link href="https://about.gitlab.com/terms/" target="_blank">{{
......@@ -165,6 +163,7 @@ export default {
}}</gl-link>
</template>
</gl-sprintf>
</span>
</gl-form-checkbox>
</gl-form-group>
......
import { GlForm, GlFormCheckbox, GlFormInput } from '@gitlab/ui';
import { createLocalVue, shallowMount } from '@vue/test-utils';
import { createLocalVue, mount, shallowMount } from '@vue/test-utils';
import VueApollo from 'vue-apollo';
import SubscriptionActivationForm, {
SUBSCRIPTION_ACTIVATION_FAILURE_EVENT,
......@@ -33,6 +33,7 @@ describe('CloudLicenseApp', () => {
const findActivateButton = () => wrapper.findByTestId('activate-button');
const findAgreementCheckbox = () => wrapper.findComponent(GlFormCheckbox);
const findAgreementCheckboxInput = () => findAgreementCheckbox().find('input');
const findAgreementCheckboxFormGroup = () => wrapper.findByTestId('form-group-terms');
const findActivationCodeFormGroup = () => wrapper.findByTestId('form-group-activation-code');
const findActivationCodeInput = () => wrapper.findComponent(GlFormInput);
......@@ -43,9 +44,13 @@ describe('CloudLicenseApp', () => {
});
const createFakeEvent = () => ({ preventDefault, stopPropagation });
const createComponentWithApollo = ({ props = {}, mutationMock } = {}) => {
const createComponentWithApollo = ({
props = {},
mutationMock,
mountMethod = shallowMount,
} = {}) => {
wrapper = extendedWrapper(
shallowMount(SubscriptionActivationForm, {
mountMethod(SubscriptionActivationForm, {
localVue,
apolloProvider: createMockApolloProvider(mutationMock),
propsData: {
......@@ -117,10 +122,10 @@ describe('CloudLicenseApp', () => {
describe('when submitting the mutation is successful', () => {
const mutationMock = jest.fn().mockResolvedValue(activateLicenseMutationResponse.SUCCESS);
beforeEach(async () => {
createComponentWithApollo({ mutationMock });
createComponentWithApollo({ mutationMock, mountMethod: mount });
jest.spyOn(wrapper.vm, 'updateSubscriptionAppCache').mockImplementation();
await findActivationCodeInput().vm.$emit('input', fakeActivationCode);
await findAgreementCheckbox().vm.$emit('input', true);
await findAgreementCheckboxInput().trigger('click');
findActivateSubscriptionForm().vm.$emit('submit', createFakeEvent());
});
......@@ -164,9 +169,9 @@ describe('CloudLicenseApp', () => {
.fn()
.mockResolvedValue(activateLicenseMutationResponse.CONNECTIVITY_ERROR);
beforeEach(async () => {
createComponentWithApollo({ mutationMock });
createComponentWithApollo({ mutationMock, mountMethod: mount });
await findActivationCodeInput().vm.$emit('input', fakeActivationCode);
await findAgreementCheckbox().vm.$emit('input', true);
await findAgreementCheckboxInput().trigger('click');
findActivateSubscriptionForm().vm.$emit('submit', createFakeEvent());
});
......@@ -182,9 +187,9 @@ describe('CloudLicenseApp', () => {
.fn()
.mockResolvedValue(activateLicenseMutationResponse.INVALID_CODE_ERROR);
beforeEach(async () => {
createComponentWithApollo({ mutationMock });
createComponentWithApollo({ mutationMock, mountMethod: mount });
await findActivationCodeInput().vm.$emit('input', fakeActivationCode);
await findAgreementCheckbox().vm.$emit('input', true);
await findAgreementCheckboxInput().trigger('click');
findActivateSubscriptionForm().vm.$emit('submit', createFakeEvent());
});
......
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