2019-10-31 17:24:18 +03:00
|
|
|
|
import Vue from 'vue'
|
|
|
|
|
import { mount, shallowMount } from '@vue/test-utils'
|
|
|
|
|
import flushPromises from 'flush-promises'
|
2019-11-01 22:51:54 +03:00
|
|
|
|
import Formulate from '@/Formulate.js'
|
2019-10-31 17:24:18 +03:00
|
|
|
|
import FormulateForm from '../src/FormulateForm.vue'
|
|
|
|
|
import FormulateInput from '../src/FormulateInput.vue'
|
|
|
|
|
|
|
|
|
|
Vue.use(Formulate)
|
|
|
|
|
|
|
|
|
|
describe('FormulateForm', () => {
|
|
|
|
|
it('render a form DOM element', () => {
|
|
|
|
|
const wrapper = mount(FormulateForm)
|
|
|
|
|
expect(wrapper.find('form').exists()).toBe(true)
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
it('accepts a default slot', () => {
|
|
|
|
|
const wrapper = mount(FormulateForm, {
|
|
|
|
|
slots: {
|
|
|
|
|
default: '<div class="default-slot-item" />'
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
expect(wrapper.find('form div.default-slot-item').exists()).toBe(true)
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
it('intercepts submit event', () => {
|
|
|
|
|
const formSubmitted = jest.fn()
|
|
|
|
|
const wrapper = mount(FormulateForm, {
|
|
|
|
|
slots: {
|
|
|
|
|
default: "<button type='submit' />"
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
formSubmitted
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
wrapper.find('form').trigger('submit')
|
|
|
|
|
expect(formSubmitted).toBeCalled()
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
it('registers its subcomponents', () => {
|
|
|
|
|
const wrapper = mount(FormulateForm, {
|
|
|
|
|
propsData: { formulateValue: { testinput: 'has initial value' } },
|
|
|
|
|
slots: { default: '<FormulateInput type="text" name="subinput1" /><FormulateInput type="checkbox" name="subinput2" />' }
|
|
|
|
|
})
|
|
|
|
|
expect(Object.keys(wrapper.vm.registry)).toEqual(['subinput1', 'subinput2'])
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
it('can set a field’s initial value', () => {
|
|
|
|
|
const wrapper = mount(FormulateForm, {
|
|
|
|
|
propsData: { formulateValue: { testinput: 'has initial value' } },
|
|
|
|
|
slots: { default: '<FormulateInput type="text" name="testinput" />' }
|
|
|
|
|
})
|
|
|
|
|
expect(wrapper.find('input').element.value).toBe('has initial value')
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
it('lets individual fields override form initial value', () => {
|
|
|
|
|
const wrapper = mount(FormulateForm, {
|
|
|
|
|
propsData: { formulateValue: { testinput: 'has initial value' } },
|
|
|
|
|
slots: { default: '<FormulateInput type="text" formulate-value="123" name="testinput" />' }
|
|
|
|
|
})
|
|
|
|
|
expect(wrapper.find('input').element.value).toBe('123')
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
it('receives updates to form model when individual fields are edited', () => {
|
|
|
|
|
const wrapper = mount({
|
|
|
|
|
data () {
|
|
|
|
|
return {
|
|
|
|
|
formValues: {
|
|
|
|
|
testinput: '',
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
template: `
|
|
|
|
|
<FormulateForm v-model="formValues">
|
|
|
|
|
<FormulateInput type="text" name="testinput" />
|
|
|
|
|
</FormulateForm>
|
|
|
|
|
`
|
|
|
|
|
})
|
|
|
|
|
wrapper.find('input').setValue('edited value')
|
|
|
|
|
expect(wrapper.vm.formValues).toEqual({ testinput: 'edited value' })
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// ===========================================================================
|
|
|
|
|
/**
|
|
|
|
|
* @todo in vue-test-utils version 1.0.0-beta.29 has some bugs related to
|
|
|
|
|
* synchronous updating. Some details are here:
|
|
|
|
|
*
|
|
|
|
|
* https://github.com/vuejs/vue-test-utils/issues/1130
|
|
|
|
|
*
|
|
|
|
|
* This test is being commented out until there is a resolution on this issue,
|
|
|
|
|
* and instead being replaced with a mock call.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
// it('updates initial form values when input contains a populated v-model', () => {
|
|
|
|
|
// const wrapper = mount({
|
|
|
|
|
// data () {
|
|
|
|
|
// return {
|
|
|
|
|
// formValues: {
|
|
|
|
|
// testinput: '',
|
|
|
|
|
// },
|
|
|
|
|
// fieldValue: '123'
|
|
|
|
|
// }
|
|
|
|
|
// },
|
|
|
|
|
// template: `
|
|
|
|
|
// <FormulateForm v-model="formValues">
|
|
|
|
|
// <FormulateInput type="text" name="testinput" v-model="fieldValue" />
|
|
|
|
|
// </FormulateForm>
|
|
|
|
|
// `
|
|
|
|
|
// })
|
|
|
|
|
// expect(wrapper.vm.formValues).toEqual({ testinput: '123' })
|
|
|
|
|
// })
|
|
|
|
|
|
|
|
|
|
// ===========================================================================
|
|
|
|
|
|
|
|
|
|
// Replacement test for the above test - not quite as good of a test.
|
|
|
|
|
it('updates calls setFieldValue on form when a field contains a populated v-model on registration', () => {
|
|
|
|
|
const wrapper = mount(FormulateForm, {
|
|
|
|
|
propsData: {
|
|
|
|
|
formulateValue: { testinput: '123' }
|
|
|
|
|
},
|
|
|
|
|
slots: {
|
|
|
|
|
default: '<FormulateInput type="text" name="testinput" formulate-value="override-data" />'
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
expect(wrapper.emitted().input[0]).toEqual([{ testinput: 'override-data' }])
|
|
|
|
|
})
|
|
|
|
|
})
|