2022-03-25 15:35:56 +08:00
|
|
|
import { nextTick, reactive, ref } from 'vue'
|
2022-03-16 15:43:49 +08:00
|
|
|
import { mount } from '@vue/test-utils'
|
2022-04-19 12:46:57 +08:00
|
|
|
import {
|
|
|
|
afterAll,
|
|
|
|
afterEach,
|
|
|
|
beforeAll,
|
|
|
|
beforeEach,
|
|
|
|
describe,
|
|
|
|
expect,
|
|
|
|
it,
|
|
|
|
vi,
|
|
|
|
} from 'vitest'
|
2022-03-16 15:43:49 +08:00
|
|
|
import { rAF } from '@element-plus/test-utils/tick'
|
|
|
|
import Input from '@element-plus/components/input'
|
2022-03-16 21:08:58 +08:00
|
|
|
import Form from '../src/form.vue'
|
2022-03-16 15:43:49 +08:00
|
|
|
import FormItem from '../src/form-item.vue'
|
|
|
|
import DynamicFormItem from '../mocks/mock-data'
|
|
|
|
|
|
|
|
import type { VueWrapper } from '@vue/test-utils'
|
2022-04-19 12:46:57 +08:00
|
|
|
import type { SpyInstance } from 'vitest'
|
2022-03-16 15:43:49 +08:00
|
|
|
import type { InputInstance } from '@element-plus/components/input'
|
|
|
|
|
|
|
|
type FormItemInstance = InstanceType<typeof FormItem>
|
|
|
|
|
|
|
|
describe('ElFormItem', () => {
|
|
|
|
let wrapper: VueWrapper<InstanceType<typeof DynamicFormItem>>
|
|
|
|
const formItemRef = ref<FormItemInstance>()
|
|
|
|
const inputRef = ref<InputInstance>()
|
|
|
|
const model = reactive({
|
|
|
|
email: '',
|
|
|
|
})
|
|
|
|
|
|
|
|
const createComponent = () => {
|
|
|
|
wrapper = mount(DynamicFormItem, {
|
|
|
|
props: {
|
|
|
|
model,
|
|
|
|
},
|
|
|
|
slots: {
|
|
|
|
default: () => (
|
|
|
|
<FormItem prop="email" required ref={formItemRef}>
|
2022-03-16 21:08:58 +08:00
|
|
|
<Input
|
|
|
|
class="input"
|
|
|
|
ref={inputRef}
|
|
|
|
v-model={model.email}
|
|
|
|
validateEvent={false}
|
|
|
|
/>
|
2022-03-16 15:43:49 +08:00
|
|
|
</FormItem>
|
|
|
|
),
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
2022-03-16 21:08:58 +08:00
|
|
|
const findForm = () => wrapper.findComponent(Form)
|
2022-03-16 15:43:49 +08:00
|
|
|
|
2022-04-19 12:46:57 +08:00
|
|
|
beforeAll(() => {
|
|
|
|
vi.spyOn(console, 'warn').mockImplementation(() => vi.fn)
|
|
|
|
})
|
|
|
|
afterAll(() => (console.warn as any as SpyInstance).mockRestore())
|
2022-03-16 15:43:49 +08:00
|
|
|
afterEach(() => {
|
|
|
|
formItemRef.value = undefined
|
|
|
|
inputRef.value = undefined
|
|
|
|
model.email = ''
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('when validation dispatches', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
createComponent()
|
|
|
|
})
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
wrapper.unmount()
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('it successes', () => {
|
|
|
|
it('should be able to validate successfully without callback', async () => {
|
|
|
|
const emailInput = formItemRef.value!
|
|
|
|
model.email = 'test'
|
|
|
|
await nextTick()
|
|
|
|
await rAF()
|
2022-03-16 21:08:58 +08:00
|
|
|
|
2022-03-16 15:43:49 +08:00
|
|
|
expect(emailInput.validate('')).resolves.toBe(true)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should be able to validate successfully with callback', async () => {
|
|
|
|
const emailInput = formItemRef.value!
|
|
|
|
model.email = 'test'
|
|
|
|
await nextTick()
|
|
|
|
await rAF()
|
2022-04-19 12:46:57 +08:00
|
|
|
const callback = vi.fn()
|
2022-03-16 21:08:58 +08:00
|
|
|
|
2022-03-16 15:43:49 +08:00
|
|
|
expect(emailInput.validate('', callback)).resolves.toBe(true)
|
|
|
|
await rAF()
|
2022-03-16 21:08:58 +08:00
|
|
|
|
2022-03-16 15:43:49 +08:00
|
|
|
expect(callback).toHaveBeenCalledWith(true)
|
|
|
|
})
|
2022-03-16 21:08:58 +08:00
|
|
|
|
|
|
|
it('should emit validate event', async () => {
|
|
|
|
const emailInput = formItemRef.value!
|
|
|
|
model.email = 'test'
|
|
|
|
await nextTick()
|
|
|
|
await emailInput.validate('')
|
|
|
|
await rAF()
|
|
|
|
|
|
|
|
expect(findForm().emitted('validate')).toEqual([['email', true, '']])
|
|
|
|
})
|
2022-03-16 15:43:49 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
describe('it fails', () => {
|
|
|
|
it('should be able to validate without callback', async () => {
|
|
|
|
const emailInput = formItemRef.value!
|
|
|
|
expect(emailInput.validate('')).rejects.toHaveProperty('email')
|
|
|
|
expect(console.warn).toHaveBeenCalled()
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should be able to validate with callback without throwing rejection', async () => {
|
|
|
|
const emailInput = formItemRef.value!
|
2022-04-19 12:46:57 +08:00
|
|
|
const callback = vi.fn()
|
2022-03-16 15:43:49 +08:00
|
|
|
expect(console.warn).toHaveBeenCalled()
|
|
|
|
expect(emailInput.validate('', callback)).resolves.toBe(false)
|
|
|
|
await rAF()
|
|
|
|
expect(callback).toHaveBeenCalled()
|
|
|
|
})
|
2022-03-16 21:08:58 +08:00
|
|
|
|
|
|
|
it('should emit validate event', async () => {
|
|
|
|
const emailInput = formItemRef.value!
|
2022-04-19 12:46:57 +08:00
|
|
|
const callback = vi.fn()
|
2022-03-16 21:08:58 +08:00
|
|
|
expect(console.warn).toHaveBeenCalled()
|
|
|
|
expect(emailInput.validate('', callback)).resolves.toBe(false)
|
|
|
|
await rAF()
|
|
|
|
expect(findForm().emitted('validate')).toEqual([
|
|
|
|
['email', false, 'email is required'],
|
|
|
|
])
|
|
|
|
})
|
2022-03-16 15:43:49 +08:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|