import Checkbox from '..'; import { mount, later } from '../../../test'; test('switch checkbox', async () => { const wrapper = mount(Checkbox); wrapper.vm.$on('input', value => { wrapper.setData({ value }); }); const icon = wrapper.find('.van-checkbox__icon'); icon.trigger('click'); await later(); icon.trigger('click'); await later(); expect(wrapper.emitted('input')).toEqual([[true], [false]]); expect(wrapper.emitted('change')).toEqual([[true], [false]]); }); test('disabled', () => { const wrapper = mount(Checkbox, { propsData: { disabled: true } }); wrapper.find('.van-checkbox__icon').trigger('click'); expect(wrapper.emitted('input')).toBeFalsy(); }); test('label disabled', () => { const wrapper = mount(Checkbox, { scopedSlots: { default: () => 'Label' }, propsData: { labelDisabled: true } }); wrapper.find('.van-checkbox__label').trigger('click'); expect(wrapper.emitted('input')).toBeFalsy(); expect(wrapper).toMatchSnapshot(); }); test('checkbox group', async () => { const wrapper = mount({ template: ` `, data() { return { result: [] }; } }); const icons = wrapper.findAll('.van-checkbox__icon'); icons.at(0).trigger('click'); await later(); icons.at(1).trigger('click'); await later(); icons.at(2).trigger('click'); expect(wrapper.vm.result).toEqual(['a', 'b']); await later(); icons.at(0).trigger('click'); await later(); expect(wrapper.vm.result).toEqual(['b']); }); test('click event', () => { const onClick = jest.fn(); const wrapper = mount(Checkbox, { listeners: { click: onClick } }); wrapper.trigger('click'); expect(onClick).toHaveBeenCalledTimes(1); const icon = wrapper.find('.van-checkbox__icon'); icon.trigger('click'); expect(onClick).toHaveBeenCalledTimes(2); }); test('label-position prop', () => { const wrapper = mount(Checkbox, { scopedSlots: { default: () => 'Label' }, propsData: { labelPosition: 'left' } }); expect(wrapper).toMatchSnapshot(); }); test('icon-size prop', () => { const wrapper = mount({ template: ` label label ` }); expect(wrapper).toMatchSnapshot(); }); test('checked-color prop', () => { const wrapper = mount({ template: ` label label ` }); expect(wrapper).toMatchSnapshot(); }); test('bind-group prop', async () => { const wrapper = mount({ template: ` `, data() { return { value: false, result: [], list: ['a', 'b', 'c'] }; } }); const icons = wrapper.findAll('.van-checkbox__icon'); icons.at(0).trigger('click'); await later(); expect(wrapper.vm.result).toEqual([]); expect(wrapper.vm.value).toBeTruthy(); }); test('toggleAll method', async () => { const wrapper = mount({ template: ` `, data() { return { result: ['a'] }; }, methods: { toggleAll(checked) { this.$refs.group.toggleAll(checked); } } }); wrapper.vm.toggleAll(); await later(); expect(wrapper.vm.result).toEqual(['b', 'c']); wrapper.vm.toggleAll(false); await later(); expect(wrapper.vm.result).toEqual([]); wrapper.vm.toggleAll(true); await later(); expect(wrapper.vm.result).toEqual(['a', 'b', 'c']); });