mirror of https://github.com/vuejs/vue.git
147 lines
2.8 KiB
JavaScript
147 lines
2.8 KiB
JavaScript
import Vue from 'vue'
|
|
import testObjectOption from '../../../helpers/test-object-option'
|
|
|
|
describe('Options watch', () => {
|
|
let spy
|
|
beforeEach(() => {
|
|
spy = jasmine.createSpy('watch')
|
|
})
|
|
|
|
testObjectOption('watch')
|
|
|
|
it('basic usage', done => {
|
|
const vm = new Vue({
|
|
data: {
|
|
a: 1
|
|
},
|
|
watch: {
|
|
a: spy
|
|
}
|
|
})
|
|
expect(spy).not.toHaveBeenCalled()
|
|
vm.a = 2
|
|
expect(spy).not.toHaveBeenCalled()
|
|
waitForUpdate(() => {
|
|
expect(spy).toHaveBeenCalledWith(2, 1)
|
|
}).then(done)
|
|
})
|
|
|
|
it('string method name', done => {
|
|
const vm = new Vue({
|
|
data: {
|
|
a: 1
|
|
},
|
|
watch: {
|
|
a: 'onChange'
|
|
},
|
|
methods: {
|
|
onChange: spy
|
|
}
|
|
})
|
|
expect(spy).not.toHaveBeenCalled()
|
|
vm.a = 2
|
|
expect(spy).not.toHaveBeenCalled()
|
|
waitForUpdate(() => {
|
|
expect(spy).toHaveBeenCalledWith(2, 1)
|
|
}).then(done)
|
|
})
|
|
|
|
it('multiple cbs (after option merge)', done => {
|
|
const spy1 = jasmine.createSpy('watch')
|
|
const Test = Vue.extend({
|
|
watch: {
|
|
a: spy1
|
|
}
|
|
})
|
|
const vm = new Test({
|
|
data: { a: 1 },
|
|
watch: {
|
|
a: spy
|
|
}
|
|
})
|
|
vm.a = 2
|
|
waitForUpdate(() => {
|
|
expect(spy1).toHaveBeenCalledWith(2, 1)
|
|
expect(spy).toHaveBeenCalledWith(2, 1)
|
|
}).then(done)
|
|
})
|
|
|
|
it('with option: immediate', done => {
|
|
const vm = new Vue({
|
|
data: { a: 1 },
|
|
watch: {
|
|
a: {
|
|
handler: spy,
|
|
immediate: true
|
|
}
|
|
}
|
|
})
|
|
expect(spy).toHaveBeenCalledWith(1)
|
|
vm.a = 2
|
|
waitForUpdate(() => {
|
|
expect(spy).toHaveBeenCalledWith(2, 1)
|
|
}).then(done)
|
|
})
|
|
|
|
it('with option: deep', done => {
|
|
const vm = new Vue({
|
|
data: { a: { b: 1 }},
|
|
watch: {
|
|
a: {
|
|
handler: spy,
|
|
deep: true
|
|
}
|
|
}
|
|
})
|
|
const oldA = vm.a
|
|
expect(spy).not.toHaveBeenCalled()
|
|
vm.a.b = 2
|
|
expect(spy).not.toHaveBeenCalled()
|
|
waitForUpdate(() => {
|
|
expect(spy).toHaveBeenCalledWith(vm.a, vm.a)
|
|
vm.a = { b: 3 }
|
|
}).then(() => {
|
|
expect(spy).toHaveBeenCalledWith(vm.a, oldA)
|
|
}).then(done)
|
|
})
|
|
|
|
it('correctly merges multiple extends', done => {
|
|
var spy2 = jasmine.createSpy('A')
|
|
var spy3 = jasmine.createSpy('B')
|
|
var A = Vue.extend({
|
|
data: function () {
|
|
return {
|
|
a: 0,
|
|
b: 0
|
|
}
|
|
},
|
|
watch: {
|
|
b: spy
|
|
}
|
|
})
|
|
|
|
var B = Vue.extend({
|
|
extends: A,
|
|
watch: {
|
|
a: spy2
|
|
}
|
|
})
|
|
|
|
var C = Vue.extend({
|
|
extends: B,
|
|
watch: {
|
|
a: spy3
|
|
}
|
|
})
|
|
|
|
var vm = new C()
|
|
vm.a = 1
|
|
|
|
waitForUpdate(() => {
|
|
expect(spy).not.toHaveBeenCalled()
|
|
expect(spy2).toHaveBeenCalledWith(1, 0)
|
|
expect(spy3).toHaveBeenCalledWith(1, 0)
|
|
}).then(done)
|
|
})
|
|
})
|