vue2/test/unit/features/instance/methods-events.spec.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

97 lines
2.4 KiB
TypeScript
Raw Normal View History

2016-05-28 09:38:06 +08:00
import Vue from 'vue'
describe('Instance methods events', () => {
let vm, spy
beforeEach(() => {
vm = new Vue({})
2022-05-20 07:56:02 +08:00
spy = vi.fn()
2016-05-28 09:38:06 +08:00
})
it('$on', () => {
vm.$on('test', function () {
// expect correct context
expect(this).toBe(vm)
spy.apply(this, arguments)
})
vm.$emit('test', 1, 2, 3, 4)
2022-05-20 07:56:02 +08:00
expect(spy.mock.calls.length).toBe(1)
2016-05-28 09:38:06 +08:00
expect(spy).toHaveBeenCalledWith(1, 2, 3, 4)
})
2017-02-16 07:39:53 +08:00
it('$on multi event', () => {
vm.$on(['test1', 'test2'], function () {
expect(this).toBe(vm)
spy.apply(this, arguments)
})
vm.$emit('test1', 1, 2, 3, 4)
2022-05-20 07:56:02 +08:00
expect(spy.mock.calls.length).toBe(1)
2017-02-16 07:39:53 +08:00
expect(spy).toHaveBeenCalledWith(1, 2, 3, 4)
vm.$emit('test2', 5, 6, 7, 8)
2022-05-20 07:56:02 +08:00
expect(spy.mock.calls.length).toBe(2)
2017-02-16 07:39:53 +08:00
expect(spy).toHaveBeenCalledWith(5, 6, 7, 8)
})
2017-03-03 11:51:57 +08:00
it('$off multi event', () => {
vm.$on(['test1', 'test2', 'test3'], spy)
vm.$off(['test1', 'test2'], spy)
vm.$emit('test1')
vm.$emit('test2')
expect(spy).not.toHaveBeenCalled()
vm.$emit('test3', 1, 2, 3, 4)
2022-05-20 07:56:02 +08:00
expect(spy.mock.calls.length).toBe(1)
2017-03-03 11:51:57 +08:00
})
it('$off multi event without callback', () => {
vm.$on(['test1', 'test2'], spy)
vm.$off(['test1', 'test2'])
vm.$emit('test1')
expect(spy).not.toHaveBeenCalled()
})
2016-05-28 09:38:06 +08:00
it('$once', () => {
vm.$once('test', spy)
vm.$emit('test', 1, 2, 3)
vm.$emit('test', 2, 3, 4)
2022-05-20 07:56:02 +08:00
expect(spy.mock.calls.length).toBe(1)
2016-05-28 09:38:06 +08:00
expect(spy).toHaveBeenCalledWith(1, 2, 3)
})
it('$off event added by $once', () => {
vm.$once('test', spy)
vm.$off('test', spy) // test off event and this event added by once
vm.$emit('test', 1, 2, 3)
expect(spy).not.toHaveBeenCalled()
})
2016-05-28 09:38:06 +08:00
it('$off', () => {
vm.$on('test1', spy)
vm.$on('test2', spy)
vm.$off()
vm.$emit('test1')
vm.$emit('test2')
expect(spy).not.toHaveBeenCalled()
})
it('$off event', () => {
vm.$on('test1', spy)
vm.$on('test2', spy)
vm.$off('test1')
vm.$off('test1') // test off something that's already off
vm.$emit('test1', 1)
vm.$emit('test2', 2)
2022-05-20 07:56:02 +08:00
expect(spy.mock.calls.length).toBe(1)
2016-05-28 09:38:06 +08:00
expect(spy).toHaveBeenCalledWith(2)
})
it('$off event + fn', () => {
2022-05-20 07:56:02 +08:00
const spy2 = vi.fn()
2016-05-28 09:38:06 +08:00
vm.$on('test', spy)
vm.$on('test', spy2)
vm.$off('test', spy)
vm.$emit('test', 1, 2, 3)
expect(spy).not.toHaveBeenCalled()
2022-05-20 07:56:02 +08:00
expect(spy2.mock.calls.length).toBe(1)
2016-05-28 09:38:06 +08:00
expect(spy2).toHaveBeenCalledWith(1, 2, 3)
})
})