|
|
@@ -17,16 +17,42 @@ describe('ssrRenderPortal', () => {
|
|
|
_push(`<div>content</div>`)
|
|
|
},
|
|
|
'#target',
|
|
|
+ false,
|
|
|
_parent
|
|
|
)
|
|
|
}
|
|
|
}),
|
|
|
ctx
|
|
|
)
|
|
|
- expect(html).toBe('<!--portal-->')
|
|
|
+ expect(html).toBe('<!--portal start--><!--portal end-->')
|
|
|
expect(ctx.portals!['#target']).toBe(`<div>content</div><!---->`)
|
|
|
})
|
|
|
|
|
|
+ test('portal rendering (compiled + disabled)', async () => {
|
|
|
+ const ctx: SSRContext = {}
|
|
|
+ const html = await renderToString(
|
|
|
+ createApp({
|
|
|
+ data() {
|
|
|
+ return { msg: 'hello' }
|
|
|
+ },
|
|
|
+ ssrRender(_ctx, _push, _parent) {
|
|
|
+ ssrRenderPortal(
|
|
|
+ _push,
|
|
|
+ _push => {
|
|
|
+ _push(`<div>content</div>`)
|
|
|
+ },
|
|
|
+ '#target',
|
|
|
+ true,
|
|
|
+ _parent
|
|
|
+ )
|
|
|
+ }
|
|
|
+ }),
|
|
|
+ ctx
|
|
|
+ )
|
|
|
+ expect(html).toBe('<!--portal start--><div>content</div><!--portal end-->')
|
|
|
+ expect(ctx.portals!['#target']).toBe(`<!---->`)
|
|
|
+ })
|
|
|
+
|
|
|
test('portal rendering (vnode)', async () => {
|
|
|
const ctx: SSRContext = {}
|
|
|
const html = await renderToString(
|
|
|
@@ -39,10 +65,27 @@ describe('ssrRenderPortal', () => {
|
|
|
),
|
|
|
ctx
|
|
|
)
|
|
|
- expect(html).toBe('<!--portal-->')
|
|
|
+ expect(html).toBe('<!--portal start--><!--portal end-->')
|
|
|
expect(ctx.portals!['#target']).toBe('<span>hello</span><!---->')
|
|
|
})
|
|
|
|
|
|
+ test('portal rendering (vnode + disabled)', async () => {
|
|
|
+ const ctx: SSRContext = {}
|
|
|
+ const html = await renderToString(
|
|
|
+ h(
|
|
|
+ Portal,
|
|
|
+ {
|
|
|
+ target: `#target`,
|
|
|
+ disabled: true
|
|
|
+ },
|
|
|
+ h('span', 'hello')
|
|
|
+ ),
|
|
|
+ ctx
|
|
|
+ )
|
|
|
+ expect(html).toBe('<!--portal start--><span>hello</span><!--portal end-->')
|
|
|
+ expect(ctx.portals!['#target']).toBe(`<!---->`)
|
|
|
+ })
|
|
|
+
|
|
|
test('multiple portals with same target', async () => {
|
|
|
const ctx: SSRContext = {}
|
|
|
const html = await renderToString(
|
|
|
@@ -58,7 +101,9 @@ describe('ssrRenderPortal', () => {
|
|
|
]),
|
|
|
ctx
|
|
|
)
|
|
|
- expect(html).toBe('<div><!--portal--><!--portal--></div>')
|
|
|
+ expect(html).toBe(
|
|
|
+ '<div><!--portal start--><!--portal end--><!--portal start--><!--portal end--></div>'
|
|
|
+ )
|
|
|
expect(ctx.portals!['#target']).toBe(
|
|
|
'<span>hello</span><!---->world<!---->'
|
|
|
)
|