test: test suspense fallback
This commit is contained in:
parent
a16c87be63
commit
3959a2a2e1
@ -10,7 +10,7 @@ import {
|
|||||||
} from '@vue/runtime-test'
|
} from '@vue/runtime-test'
|
||||||
|
|
||||||
describe('renderer: suspense', () => {
|
describe('renderer: suspense', () => {
|
||||||
it('should work', async () => {
|
it('basic usage (nested + multiple deps)', async () => {
|
||||||
const msg = ref('hello')
|
const msg = ref('hello')
|
||||||
const deps: Promise<any>[] = []
|
const deps: Promise<any>[] = []
|
||||||
|
|
||||||
@ -59,7 +59,6 @@ describe('renderer: suspense', () => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const Comp = {
|
const Comp = {
|
||||||
name: 'root',
|
|
||||||
setup() {
|
setup() {
|
||||||
return () =>
|
return () =>
|
||||||
h(Suspense, [msg.value, h(Mid), h(AsyncChild2, { msg: 'child 2' })])
|
h(Suspense, [msg.value, h(Mid), h(AsyncChild2, { msg: 'child 2' })])
|
||||||
@ -77,13 +76,50 @@ describe('renderer: suspense', () => {
|
|||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|
||||||
test.todo('buffer mounted/updated hooks & watch callbacks')
|
test('fallback content', async () => {
|
||||||
|
const deps: Promise<any>[] = []
|
||||||
|
|
||||||
test.todo('fallback content')
|
const Async = {
|
||||||
|
async setup() {
|
||||||
|
const p = new Promise(r => setTimeout(r, 1))
|
||||||
|
deps.push(p)
|
||||||
|
await p
|
||||||
|
// test resume for returning bindings
|
||||||
|
return {
|
||||||
|
msg: 'async'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
render(this: any) {
|
||||||
|
return h('div', this.msg)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const Comp = {
|
||||||
|
setup() {
|
||||||
|
return () =>
|
||||||
|
h(Suspense, null, {
|
||||||
|
default: h(Async),
|
||||||
|
fallback: h('div', 'fallback')
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const root = nodeOps.createElement('div')
|
||||||
|
render(h(Comp), root)
|
||||||
|
expect(serializeInner(root)).toBe(`<div>fallback</div>`)
|
||||||
|
|
||||||
|
await Promise.all(deps)
|
||||||
|
await nextTick()
|
||||||
|
expect(serializeInner(root)).toBe(`<div>async</div>`)
|
||||||
|
})
|
||||||
|
|
||||||
|
test.todo('buffer mounted/updated hooks & watch callbacks')
|
||||||
|
|
||||||
test.todo('content update before suspense resolve')
|
test.todo('content update before suspense resolve')
|
||||||
|
|
||||||
test.todo('unmount before suspense resolve')
|
test.todo('unmount before suspense resolve')
|
||||||
|
|
||||||
test.todo('nested suspense')
|
test.todo('nested suspense')
|
||||||
|
|
||||||
|
test.todo('error handling')
|
||||||
})
|
})
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
import { VNode, normalizeVNode } from './vnode'
|
import { VNode, normalizeVNode } from './vnode'
|
||||||
import { ShapeFlags } from '.'
|
import { ShapeFlags } from '.'
|
||||||
|
import { isFunction } from '@vue/shared'
|
||||||
|
|
||||||
export const SuspenseSymbol = __DEV__ ? Symbol('Suspense key') : Symbol()
|
export const SuspenseSymbol = __DEV__ ? Symbol('Suspense key') : Symbol()
|
||||||
|
|
||||||
@ -48,16 +49,16 @@ export function normalizeSuspenseChildren(
|
|||||||
content: VNode
|
content: VNode
|
||||||
fallback: VNode
|
fallback: VNode
|
||||||
} {
|
} {
|
||||||
const { shapeFlag } = vnode
|
const { shapeFlag, children } = vnode
|
||||||
const children = vnode.children as any
|
|
||||||
if (shapeFlag & ShapeFlags.SLOTS_CHILDREN) {
|
if (shapeFlag & ShapeFlags.SLOTS_CHILDREN) {
|
||||||
|
const { default: d, fallback } = children as any
|
||||||
return {
|
return {
|
||||||
content: normalizeVNode(children.default()),
|
content: normalizeVNode(isFunction(d) ? d() : d),
|
||||||
fallback: normalizeVNode(children.fallback ? children.fallback() : null)
|
fallback: normalizeVNode(isFunction(fallback) ? fallback() : fallback)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return {
|
return {
|
||||||
content: normalizeVNode(children),
|
content: normalizeVNode(children as any),
|
||||||
fallback: normalizeVNode(null)
|
fallback: normalizeVNode(null)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user