2021-04-29 05:21:02 +08:00
|
|
|
import Vue from '@vue/compat'
|
2021-04-30 04:58:14 +08:00
|
|
|
import { nextTick } from '../../runtime-core/src/scheduler'
|
2021-04-29 05:21:02 +08:00
|
|
|
import {
|
|
|
|
DeprecationTypes,
|
|
|
|
deprecationData,
|
|
|
|
toggleDeprecationWarning
|
2021-04-30 04:58:14 +08:00
|
|
|
} from '../../runtime-core/src/compat/compatConfig'
|
2021-04-29 05:21:02 +08:00
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
toggleDeprecationWarning(true)
|
|
|
|
Vue.configureCompat({
|
|
|
|
MODE: 2,
|
|
|
|
GLOBAL_MOUNT: 'suppress-warning'
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
toggleDeprecationWarning(false)
|
|
|
|
Vue.configureCompat({ MODE: 3 })
|
|
|
|
})
|
|
|
|
|
|
|
|
test('root data plain object', () => {
|
|
|
|
const vm = new Vue({
|
|
|
|
data: { foo: 1 } as any,
|
|
|
|
template: `{{ foo }}`
|
|
|
|
}).$mount()
|
|
|
|
expect(vm.$el.textContent).toBe('1')
|
|
|
|
expect(
|
|
|
|
deprecationData[DeprecationTypes.OPTIONS_DATA_FN].message
|
|
|
|
).toHaveBeenWarned()
|
|
|
|
})
|
|
|
|
|
|
|
|
test('data deep merge', () => {
|
|
|
|
const mixin = {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
foo: {
|
|
|
|
baz: 2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const vm = new Vue({
|
|
|
|
mixins: [mixin],
|
|
|
|
data: () => ({
|
|
|
|
foo: {
|
|
|
|
bar: 1
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
template: `{{ foo }}`
|
|
|
|
}).$mount()
|
|
|
|
|
|
|
|
expect(vm.$el.textContent).toBe(JSON.stringify({ baz: 2, bar: 1 }, null, 2))
|
|
|
|
expect(
|
|
|
|
(deprecationData[DeprecationTypes.OPTIONS_DATA_MERGE].message as Function)(
|
|
|
|
'foo'
|
|
|
|
)
|
|
|
|
).toHaveBeenWarned()
|
|
|
|
})
|
|
|
|
|
|
|
|
test('beforeDestroy/destroyed', async () => {
|
|
|
|
const beforeDestroy = jest.fn()
|
|
|
|
const destroyed = jest.fn()
|
|
|
|
|
|
|
|
const child = {
|
|
|
|
template: `foo`,
|
|
|
|
beforeDestroy,
|
|
|
|
destroyed
|
|
|
|
}
|
|
|
|
|
|
|
|
const vm = new Vue({
|
|
|
|
template: `<child v-if="ok"/>`,
|
|
|
|
data() {
|
|
|
|
return { ok: true }
|
|
|
|
},
|
|
|
|
components: { child }
|
|
|
|
}).$mount() as any
|
|
|
|
|
|
|
|
vm.ok = false
|
|
|
|
await nextTick()
|
|
|
|
expect(beforeDestroy).toHaveBeenCalled()
|
|
|
|
expect(destroyed).toHaveBeenCalled()
|
|
|
|
|
|
|
|
expect(
|
|
|
|
deprecationData[DeprecationTypes.OPTIONS_BEFORE_DESTROY].message
|
|
|
|
).toHaveBeenWarned()
|
|
|
|
|
|
|
|
expect(
|
|
|
|
deprecationData[DeprecationTypes.OPTIONS_DESTROYED].message
|
|
|
|
).toHaveBeenWarned()
|
|
|
|
})
|