Commit 4c7235af authored by Samantha Ming's avatar Samantha Ming

Add validation initForm helper

This helper will make it easier to create the form object
that is compliant with the validation directive usage.
parent 3983ee99
...@@ -136,3 +136,59 @@ export default function initValidation(customFeedbackMap = {}) { ...@@ -136,3 +136,59 @@ export default function initValidation(customFeedbackMap = {}) {
}, },
}; };
} }
/**
* This is a helper that initialize the form fields structure to be used in initForm
* @param {*} fieldValues
* @returns formObject
*/
const initFormField = ({ value, required = true, skipValidation = false }) => ({
value,
required,
state: skipValidation ? true : null,
feedback: null,
});
/**
* This is a helper that initialize the form structure that is compliant to be used with the validation directive
*
* @example
* const form initForm = initForm({
* fields: {
* name: {
* value: 'lorem'
* },
* description: {
* value: 'ipsum',
* required: false,
* skipValidation: true
* }
* }
* })
*
* @example
* const form initForm = initForm({
* state: true, // to override
* foo: { // something custom
* bar: 'lorem'
* },
* fields: {...}
* })
*
* @param {*} formObject
* @returns form
*/
export const initForm = ({ fields = {}, ...rest } = {}) => {
const initFields = Object.fromEntries(
Object.entries(fields).map(([fieldName, fieldValues]) => {
return [fieldName, initFormField(fieldValues)];
}),
);
return {
state: false,
showValidation: false,
...rest,
fields: initFields,
};
};
import { shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import validation from '~/vue_shared/directives/validation'; import validation, { initForm } from '~/vue_shared/directives/validation';
describe('validation directive', () => { describe('validation directive', () => {
let wrapper; let wrapper;
const createComponent = ({ inputAttributes, showValidation, template } = {}) => { const createComponentFactory = ({ inputAttributes, template, data }) => {
const defaultInputAttributes = { const defaultInputAttributes = {
type: 'text', type: 'text',
required: true, required: true,
...@@ -23,6 +23,19 @@ describe('validation directive', () => { ...@@ -23,6 +23,19 @@ describe('validation directive', () => {
data() { data() {
return { return {
attributes: inputAttributes || defaultInputAttributes, attributes: inputAttributes || defaultInputAttributes,
...data,
};
},
template: template || defaultTemplate,
};
wrapper = shallowMount(component, { attachTo: document.body });
};
const createComponent = ({ inputAttributes, showValidation, template } = {}) =>
createComponentFactory({
inputAttributes,
data: {
showValidation, showValidation,
form: { form: {
state: null, state: null,
...@@ -33,13 +46,29 @@ describe('validation directive', () => { ...@@ -33,13 +46,29 @@ describe('validation directive', () => {
}, },
}, },
}, },
};
}, },
template: template || defaultTemplate, template,
}; });
wrapper = shallowMount(component, { attachTo: document.body }); const createComponentWithInitForm = ({ inputAttributes } = {}) =>
}; createComponentFactory({
inputAttributes,
data: {
form: initForm({
fields: {
exampleField: {
state: null,
value: 'lorem',
},
},
}),
},
template: `
<form>
<input v-validation:[form.showValidation] name="exampleField" v-bind="attributes" />
</form>
`,
});
afterEach(() => { afterEach(() => {
wrapper.destroy(); wrapper.destroy();
...@@ -179,4 +208,86 @@ describe('validation directive', () => { ...@@ -179,4 +208,86 @@ describe('validation directive', () => {
}); });
}); });
}); });
describe('component using initForm', () => {
it('sets the form fields correctly', () => {
createComponentWithInitForm();
expect(getFormData().state).toBe(false);
expect(getFormData().showValidation).toBe(false);
expect(getFormData().fields.exampleField).toMatchObject({
value: 'lorem',
state: null,
required: true,
feedback: expect.any(String),
});
});
});
});
describe('initForm', () => {
const MOCK_FORM = {
fields: {
name: {
value: 'lorem',
},
description: {
value: 'ipsum',
required: false,
skipValidation: true,
},
},
};
it('returns form object', () => {
expect(initForm(MOCK_FORM)).toMatchObject({
state: false,
showValidation: false,
fields: {
name: { value: 'lorem', required: true, state: null, feedback: null },
description: { value: 'ipsum', required: false, state: true, feedback: null },
},
});
});
it('returns form object with additional parameters', () => {
const customFormObject = {
foo: {
bar: 'lorem',
},
};
const form = {
...MOCK_FORM,
...customFormObject,
};
expect(initForm(form)).toMatchObject({
state: false,
showValidation: false,
fields: {
name: { value: 'lorem', required: true, state: null, feedback: null },
description: { value: 'ipsum', required: false, state: true, feedback: null },
},
...customFormObject,
});
});
it('can override existing state and showValidation values', () => {
const form = {
...MOCK_FORM,
state: true,
showValidation: true,
};
expect(initForm(form)).toMatchObject({
state: true,
showValidation: true,
fields: {
name: { value: 'lorem', required: true, state: null, feedback: null },
description: { value: 'ipsum', required: false, state: true, feedback: null },
},
});
});
}); });
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