test: add checkbox & switch test

pull/165/head
tjz 2018-05-20 21:42:23 +08:00
parent c8167d6b36
commit 3d83df36af
4 changed files with 111 additions and 0 deletions

View File

@ -0,0 +1,26 @@
import { mount } from '@vue/test-utils'
import Checkbox from '..'
import focusTest from '../../../tests/shared/focusTest'
describe('Checkbox', () => {
focusTest(Checkbox)
it('responses hover events', () => {
const onMouseEnter = jest.fn()
const onMouseLeave = jest.fn()
const wrapper = mount(Checkbox, {
listeners: {
mouseenter: onMouseEnter,
mouseleave: onMouseLeave,
},
})
wrapper.trigger('mouseenter')
expect(onMouseEnter).toHaveBeenCalled()
wrapper.trigger('mouseleave')
expect(onMouseLeave).toHaveBeenCalled()
})
})

View File

@ -0,0 +1,65 @@
import { mount } from '@vue/test-utils'
import Checkbox from '../index'
describe('CheckboxGroup', () => {
it('should work basically', () => {
const onChange = jest.fn()
const wrapper = mount(
{
render () {
return <Checkbox.Group options={['Apple', 'Pear', 'Orange']} onChange={onChange} />
},
}
)
wrapper.findAll('.ant-checkbox-input').at(0).trigger('change')
expect(onChange).toBeCalledWith(['Apple'])
wrapper.findAll('.ant-checkbox-input').at(1).trigger('change')
expect(onChange).toBeCalledWith(['Apple', 'Pear'])
wrapper.findAll('.ant-checkbox-input').at(2).trigger('change')
expect(onChange).toBeCalledWith(['Apple', 'Pear', 'Orange'])
wrapper.findAll('.ant-checkbox-input').at(1).trigger('change')
expect(onChange).toBeCalledWith(['Apple', 'Orange'])
})
it('does not trigger onChange callback of both Checkbox and CheckboxGroup when CheckboxGroup is disabled', () => {
const onChangeGroup = jest.fn()
const options = [
{ label: 'Apple', value: 'Apple' },
{ label: 'Pear', value: 'Pear' },
]
const groupWrapper = mount(
{
render () {
return <Checkbox.Group options={options} onChange={onChangeGroup} disabled />
},
}
)
groupWrapper.findAll('.ant-checkbox-input').at(0).trigger('change')
expect(onChangeGroup).not.toBeCalled()
groupWrapper.findAll('.ant-checkbox-input').at(1).trigger('change')
expect(onChangeGroup).not.toBeCalled()
})
it('does not prevent onChange callback from Checkbox when CheckboxGroup is not disabled', () => {
const onChangeGroup = jest.fn()
const options = [
{ label: 'Apple', value: 'Apple' },
{ label: 'Orange', value: 'Orange', disabled: true },
]
const groupWrapper = mount(
{
render () {
return <Checkbox.Group options={options} onChange={onChangeGroup} />
},
}
)
groupWrapper.findAll('.ant-checkbox-input').at(0).trigger('change')
expect(onChangeGroup).toBeCalledWith(['Apple'])
groupWrapper.findAll('.ant-checkbox-input').at(1).trigger('change')
expect(onChangeGroup).toBeCalledWith(['Apple'])
})
})

View File

@ -0,0 +1,6 @@
import Switch from '..'
import focusTest from '../../../tests/shared/focusTest'
describe('Switch', () => {
focusTest(Switch)
})

View File

@ -31,3 +31,17 @@ Vue.component('transition-group', {
},
})
Vue.prototype.$emit = function () {
const vm = this
const args = [].slice.call(arguments, 0)
const filterEvent = []
const eventName = args[0]
if (args.length && vm.$listeners[eventName]) {
if (filterEvent.includes(eventName)) {
vm.$emit(eventName, ...args.slice(1))
} else {
vm.$listeners[eventName](...args.slice(1))
}
}
}