import Vue from 'vue' import { mount } from '@vue/test-utils' import flushPromises from 'flush-promises' import Formulario from '@/index.ts' import FormularioForm from '@/FormularioForm.vue' import FormularioGrouping from '@/FormularioGrouping.vue' Vue.use(Formulario) describe('FormularioGrouping', () => { it('grouped fields to be setted', async () => { const wrapper = mount(FormularioForm, { propsData: { name: 'form', }, slots: { default: ` ` } }) expect(wrapper.findAll('input[type="text"]').length).toBe(1) wrapper.find('input[type="text"]').setValue('test') const submission = await wrapper.vm.formSubmitted() expect(submission).toEqual({sub: {text: 'test'}}) }) it('grouped fields to be getted', async () => { const wrapper = mount(FormularioForm, { propsData: { name: 'form', formularioValue: { sub: {text: 'initial value'}, text: 'simple text' } }, slots: { default: ` ` } }) expect(wrapper.find('input[type="text"]').element.value).toBe('initial value') }) it('data reactive with grouped fields', async () => { const wrapper = mount({ data () { return { formValues: {} } }, template: ` {{ formValues.sub.text }} ` }) expect(wrapper.find('span').text()).toBe('') wrapper.find('input[type="text"]').setValue('test') await flushPromises() expect(wrapper.find('span').text()).toBe('test') }) it('errors are setted for grouped fields', async () => { const wrapper = mount({ data () { return { formValues: {} } }, template: ` {{ error }} ` }) expect(wrapper.findAll('span').length).toBe(1) }) })