2020-02-06 04:07:23 +00:00
|
|
|
import { compile } from '../src'
|
|
|
|
|
|
|
|
describe('ssr: components', () => {
|
|
|
|
test('basic', () => {
|
|
|
|
expect(compile(`<foo id="a" :prop="b" />`).code).toMatchInlineSnapshot(`
|
2020-06-26 18:23:50 +00:00
|
|
|
"const { resolveComponent: _resolveComponent, mergeProps: _mergeProps } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderComponent: _ssrRenderComponent } = require(\\"vue/server-renderer\\")
|
2020-02-06 04:07:23 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-02-08 00:04:55 +00:00
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
2020-02-06 04:07:23 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
_push(_ssrRenderComponent(_component_foo, _mergeProps({
|
2020-02-06 04:07:23 +00:00
|
|
|
id: \\"a\\",
|
|
|
|
prop: _ctx.b
|
2020-06-26 18:23:50 +00:00
|
|
|
}, _attrs), null, _parent))
|
2020-02-06 04:07:23 +00:00
|
|
|
}"
|
|
|
|
`)
|
2022-05-17 07:50:23 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
// event listeners should still be passed
|
|
|
|
test('event listeners', () => {
|
|
|
|
expect(compile(`<foo @click="bar" />`).code).toMatchInlineSnapshot(`
|
|
|
|
"const { resolveComponent: _resolveComponent, mergeProps: _mergeProps } = require(\\"vue\\")
|
|
|
|
const { ssrRenderComponent: _ssrRenderComponent } = require(\\"vue/server-renderer\\")
|
|
|
|
|
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
|
|
|
|
|
|
|
_push(_ssrRenderComponent(_component_foo, _mergeProps({ onClick: _ctx.bar }, _attrs), null, _parent))
|
|
|
|
}"
|
|
|
|
`)
|
2020-02-06 04:07:23 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
test('dynamic component', () => {
|
|
|
|
expect(compile(`<component is="foo" prop="b" />`).code)
|
|
|
|
.toMatchInlineSnapshot(`
|
2020-07-07 01:23:29 +00:00
|
|
|
"const { resolveDynamicComponent: _resolveDynamicComponent, mergeProps: _mergeProps, createVNode: _createVNode } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderVNode: _ssrRenderVNode } = require(\\"vue/server-renderer\\")
|
2020-02-06 04:07:23 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-07-07 01:23:29 +00:00
|
|
|
_ssrRenderVNode(_push, _createVNode(_resolveDynamicComponent(\\"foo\\"), _mergeProps({ prop: \\"b\\" }, _attrs), null), _parent)
|
2020-02-06 04:07:23 +00:00
|
|
|
}"
|
|
|
|
`)
|
|
|
|
|
2020-02-10 14:20:07 +00:00
|
|
|
expect(compile(`<component :is="foo" prop="b" />`).code)
|
2020-02-06 04:07:23 +00:00
|
|
|
.toMatchInlineSnapshot(`
|
2020-07-07 01:23:29 +00:00
|
|
|
"const { resolveDynamicComponent: _resolveDynamicComponent, mergeProps: _mergeProps, createVNode: _createVNode } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderVNode: _ssrRenderVNode } = require(\\"vue/server-renderer\\")
|
2020-03-10 20:52:08 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-07-07 01:23:29 +00:00
|
|
|
_ssrRenderVNode(_push, _createVNode(_resolveDynamicComponent(_ctx.foo), _mergeProps({ prop: \\"b\\" }, _attrs), null), _parent)
|
2020-02-06 04:07:23 +00:00
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
2020-02-06 17:05:53 +00:00
|
|
|
|
|
|
|
describe('slots', () => {
|
|
|
|
test('implicit default slot', () => {
|
|
|
|
expect(compile(`<foo>hello<div/></foo>`).code).toMatchInlineSnapshot(`
|
2020-03-16 15:23:29 +00:00
|
|
|
"const { resolveComponent: _resolveComponent, withCtx: _withCtx, createVNode: _createVNode, createTextVNode: _createTextVNode } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderComponent: _ssrRenderComponent } = require(\\"vue/server-renderer\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-02-08 00:04:55 +00:00
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
_push(_ssrRenderComponent(_component_foo, _attrs, {
|
2020-03-16 15:23:29 +00:00
|
|
|
default: _withCtx((_, _push, _parent, _scopeId) => {
|
2020-02-07 06:06:51 +00:00
|
|
|
if (_push) {
|
|
|
|
_push(\`hello<div\${_scopeId}></div>\`)
|
2020-02-06 22:45:34 +00:00
|
|
|
} else {
|
2020-02-07 06:06:51 +00:00
|
|
|
return [
|
2020-02-08 00:04:55 +00:00
|
|
|
_createTextVNode(\\"hello\\"),
|
|
|
|
_createVNode(\\"div\\")
|
2020-02-07 06:06:51 +00:00
|
|
|
]
|
2020-02-06 22:45:34 +00:00
|
|
|
}
|
2020-03-16 17:06:37 +00:00
|
|
|
}),
|
2020-11-30 20:11:58 +00:00
|
|
|
_: 1 /* STABLE */
|
2020-02-06 23:03:14 +00:00
|
|
|
}, _parent))
|
2020-02-06 17:05:53 +00:00
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('explicit default slot', () => {
|
|
|
|
expect(compile(`<foo v-slot="{ msg }">{{ msg + outer }}</foo>`).code)
|
|
|
|
.toMatchInlineSnapshot(`
|
2020-03-16 15:23:29 +00:00
|
|
|
"const { resolveComponent: _resolveComponent, withCtx: _withCtx, toDisplayString: _toDisplayString, createTextVNode: _createTextVNode } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderComponent: _ssrRenderComponent, ssrInterpolate: _ssrInterpolate } = require(\\"vue/server-renderer\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-02-08 00:04:55 +00:00
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
_push(_ssrRenderComponent(_component_foo, _attrs, {
|
2020-03-16 15:23:29 +00:00
|
|
|
default: _withCtx(({ msg }, _push, _parent, _scopeId) => {
|
2020-02-07 06:06:51 +00:00
|
|
|
if (_push) {
|
|
|
|
_push(\`\${_ssrInterpolate(msg + _ctx.outer)}\`)
|
|
|
|
} else {
|
|
|
|
return [
|
2020-03-06 19:52:15 +00:00
|
|
|
_createTextVNode(_toDisplayString(msg + _ctx.outer), 1 /* TEXT */)
|
2020-02-07 06:06:51 +00:00
|
|
|
]
|
|
|
|
}
|
2020-03-16 17:06:37 +00:00
|
|
|
}),
|
2020-11-30 20:11:58 +00:00
|
|
|
_: 1 /* STABLE */
|
2020-02-06 23:03:14 +00:00
|
|
|
}, _parent))
|
2020-02-06 17:05:53 +00:00
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('named slots', () => {
|
|
|
|
expect(
|
|
|
|
compile(`<foo>
|
|
|
|
<template v-slot>foo</template>
|
|
|
|
<template v-slot:named>bar</template>
|
|
|
|
</foo>`).code
|
|
|
|
).toMatchInlineSnapshot(`
|
2020-03-16 15:23:29 +00:00
|
|
|
"const { resolveComponent: _resolveComponent, withCtx: _withCtx, createTextVNode: _createTextVNode } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderComponent: _ssrRenderComponent } = require(\\"vue/server-renderer\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-02-08 00:04:55 +00:00
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
_push(_ssrRenderComponent(_component_foo, _attrs, {
|
2020-03-16 15:23:29 +00:00
|
|
|
default: _withCtx((_, _push, _parent, _scopeId) => {
|
2020-02-07 06:06:51 +00:00
|
|
|
if (_push) {
|
|
|
|
_push(\`foo\`)
|
|
|
|
} else {
|
|
|
|
return [
|
2020-02-08 00:04:55 +00:00
|
|
|
_createTextVNode(\\"foo\\")
|
2020-02-07 06:06:51 +00:00
|
|
|
]
|
|
|
|
}
|
2020-03-16 17:06:37 +00:00
|
|
|
}),
|
2020-03-16 15:23:29 +00:00
|
|
|
named: _withCtx((_, _push, _parent, _scopeId) => {
|
2020-02-07 06:06:51 +00:00
|
|
|
if (_push) {
|
|
|
|
_push(\`bar\`)
|
|
|
|
} else {
|
|
|
|
return [
|
2020-02-08 00:04:55 +00:00
|
|
|
_createTextVNode(\\"bar\\")
|
2020-02-07 06:06:51 +00:00
|
|
|
]
|
|
|
|
}
|
2020-03-16 17:06:37 +00:00
|
|
|
}),
|
2020-11-30 20:11:58 +00:00
|
|
|
_: 1 /* STABLE */
|
2020-02-06 23:03:14 +00:00
|
|
|
}, _parent))
|
2020-02-06 17:05:53 +00:00
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('v-if slot', () => {
|
|
|
|
expect(
|
|
|
|
compile(`<foo>
|
|
|
|
<template v-slot:named v-if="ok">foo</template>
|
|
|
|
</foo>`).code
|
|
|
|
).toMatchInlineSnapshot(`
|
2020-03-16 15:23:29 +00:00
|
|
|
"const { resolveComponent: _resolveComponent, withCtx: _withCtx, createTextVNode: _createTextVNode, createSlots: _createSlots } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderComponent: _ssrRenderComponent } = require(\\"vue/server-renderer\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-02-08 00:04:55 +00:00
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-11-30 20:11:58 +00:00
|
|
|
_push(_ssrRenderComponent(_component_foo, _attrs, _createSlots({ _: 2 /* DYNAMIC */ }, [
|
2020-02-06 17:05:53 +00:00
|
|
|
(_ctx.ok)
|
|
|
|
? {
|
|
|
|
name: \\"named\\",
|
2020-03-16 15:23:29 +00:00
|
|
|
fn: _withCtx((_, _push, _parent, _scopeId) => {
|
2020-02-07 06:06:51 +00:00
|
|
|
if (_push) {
|
|
|
|
_push(\`foo\`)
|
|
|
|
} else {
|
|
|
|
return [
|
2020-02-08 00:04:55 +00:00
|
|
|
_createTextVNode(\\"foo\\")
|
2020-02-07 06:06:51 +00:00
|
|
|
]
|
|
|
|
}
|
2020-03-16 17:06:37 +00:00
|
|
|
})
|
2020-02-06 17:05:53 +00:00
|
|
|
}
|
|
|
|
: undefined
|
2020-02-06 23:03:14 +00:00
|
|
|
]), _parent))
|
2020-02-06 17:05:53 +00:00
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('v-for slot', () => {
|
|
|
|
expect(
|
|
|
|
compile(`<foo>
|
|
|
|
<template v-for="key in names" v-slot:[key]="{ msg }">{{ msg + key + bar }}</template>
|
|
|
|
</foo>`).code
|
|
|
|
).toMatchInlineSnapshot(`
|
2020-03-16 15:23:29 +00:00
|
|
|
"const { resolveComponent: _resolveComponent, withCtx: _withCtx, toDisplayString: _toDisplayString, createTextVNode: _createTextVNode, renderList: _renderList, createSlots: _createSlots } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderComponent: _ssrRenderComponent, ssrInterpolate: _ssrInterpolate } = require(\\"vue/server-renderer\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-02-08 00:04:55 +00:00
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
2020-02-06 17:05:53 +00:00
|
|
|
|
2020-11-30 20:11:58 +00:00
|
|
|
_push(_ssrRenderComponent(_component_foo, _attrs, _createSlots({ _: 2 /* DYNAMIC */ }, [
|
2020-02-08 00:04:55 +00:00
|
|
|
_renderList(_ctx.names, (key) => {
|
2020-02-06 17:05:53 +00:00
|
|
|
return {
|
|
|
|
name: key,
|
2020-03-16 15:23:29 +00:00
|
|
|
fn: _withCtx(({ msg }, _push, _parent, _scopeId) => {
|
2020-02-07 18:56:18 +00:00
|
|
|
if (_push) {
|
|
|
|
_push(\`\${_ssrInterpolate(msg + key + _ctx.bar)}\`)
|
|
|
|
} else {
|
|
|
|
return [
|
2020-03-06 19:52:15 +00:00
|
|
|
_createTextVNode(_toDisplayString(msg + _ctx.key + _ctx.bar), 1 /* TEXT */)
|
2020-02-07 18:56:18 +00:00
|
|
|
]
|
|
|
|
}
|
2020-03-16 17:06:37 +00:00
|
|
|
})
|
2020-02-06 17:05:53 +00:00
|
|
|
}
|
|
|
|
})
|
2020-02-06 23:03:14 +00:00
|
|
|
]), _parent))
|
2020-02-06 17:05:53 +00:00
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
2020-02-06 20:29:02 +00:00
|
|
|
|
2020-02-07 18:56:18 +00:00
|
|
|
test('nested transform scoping in vnode branch', () => {
|
|
|
|
expect(
|
|
|
|
compile(`<foo>
|
|
|
|
<template v-slot:foo="{ list }">
|
|
|
|
<div v-if="ok">
|
|
|
|
<span v-for="i in list"></span>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<template v-slot:bar="{ ok }">
|
|
|
|
<div v-if="ok">
|
|
|
|
<span v-for="i in list"></span>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</foo>`).code
|
|
|
|
).toMatchInlineSnapshot(`
|
2021-03-25 21:01:50 +00:00
|
|
|
"const { resolveComponent: _resolveComponent, withCtx: _withCtx, renderList: _renderList, Fragment: _Fragment, openBlock: _openBlock, createBlock: _createBlock, createCommentVNode: _createCommentVNode } = require(\\"vue\\")
|
2021-09-23 03:28:13 +00:00
|
|
|
const { ssrRenderComponent: _ssrRenderComponent, ssrRenderList: _ssrRenderList } = require(\\"vue/server-renderer\\")
|
2020-02-07 18:56:18 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
2020-02-08 00:04:55 +00:00
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
2020-02-07 18:56:18 +00:00
|
|
|
|
2020-06-26 18:23:50 +00:00
|
|
|
_push(_ssrRenderComponent(_component_foo, _attrs, {
|
2020-03-16 15:23:29 +00:00
|
|
|
foo: _withCtx(({ list }, _push, _parent, _scopeId) => {
|
2020-02-07 18:56:18 +00:00
|
|
|
if (_push) {
|
|
|
|
if (_ctx.ok) {
|
2020-03-13 15:55:04 +00:00
|
|
|
_push(\`<div\${_scopeId}><!--[-->\`)
|
2020-02-07 18:56:18 +00:00
|
|
|
_ssrRenderList(list, (i) => {
|
|
|
|
_push(\`<span\${_scopeId}></span>\`)
|
|
|
|
})
|
2020-03-13 15:55:04 +00:00
|
|
|
_push(\`<!--]--></div>\`)
|
2020-02-07 18:56:18 +00:00
|
|
|
} else {
|
|
|
|
_push(\`<!---->\`)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return [
|
2020-02-11 23:40:21 +00:00
|
|
|
(_ctx.ok)
|
|
|
|
? (_openBlock(), _createBlock(\\"div\\", { key: 0 }, [
|
2020-02-10 23:19:49 +00:00
|
|
|
(_openBlock(true), _createBlock(_Fragment, null, _renderList(list, (i) => {
|
2020-02-08 00:04:55 +00:00
|
|
|
return (_openBlock(), _createBlock(\\"span\\"))
|
2020-02-07 18:56:18 +00:00
|
|
|
}), 256 /* UNKEYED_FRAGMENT */))
|
2020-02-11 23:40:21 +00:00
|
|
|
]))
|
|
|
|
: _createCommentVNode(\\"v-if\\", true)
|
2020-02-07 18:56:18 +00:00
|
|
|
]
|
|
|
|
}
|
2020-03-16 17:06:37 +00:00
|
|
|
}),
|
2020-03-16 15:23:29 +00:00
|
|
|
bar: _withCtx(({ ok }, _push, _parent, _scopeId) => {
|
2020-02-07 18:56:18 +00:00
|
|
|
if (_push) {
|
|
|
|
if (ok) {
|
2020-03-13 15:55:04 +00:00
|
|
|
_push(\`<div\${_scopeId}><!--[-->\`)
|
2020-02-07 18:56:18 +00:00
|
|
|
_ssrRenderList(_ctx.list, (i) => {
|
|
|
|
_push(\`<span\${_scopeId}></span>\`)
|
|
|
|
})
|
2020-03-13 15:55:04 +00:00
|
|
|
_push(\`<!--]--></div>\`)
|
2020-02-07 18:56:18 +00:00
|
|
|
} else {
|
|
|
|
_push(\`<!---->\`)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return [
|
2020-02-11 23:40:21 +00:00
|
|
|
ok
|
|
|
|
? (_openBlock(), _createBlock(\\"div\\", { key: 0 }, [
|
2020-02-10 23:19:49 +00:00
|
|
|
(_openBlock(true), _createBlock(_Fragment, null, _renderList(_ctx.list, (i) => {
|
2020-02-08 00:04:55 +00:00
|
|
|
return (_openBlock(), _createBlock(\\"span\\"))
|
2020-02-07 18:56:18 +00:00
|
|
|
}), 256 /* UNKEYED_FRAGMENT */))
|
2020-02-11 23:40:21 +00:00
|
|
|
]))
|
|
|
|
: _createCommentVNode(\\"v-if\\", true)
|
2020-02-07 18:56:18 +00:00
|
|
|
]
|
|
|
|
}
|
2020-03-16 17:06:37 +00:00
|
|
|
}),
|
2020-11-30 20:11:58 +00:00
|
|
|
_: 1 /* STABLE */
|
2020-02-07 18:56:18 +00:00
|
|
|
}, _parent))
|
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
2022-05-18 01:28:18 +00:00
|
|
|
describe('built-in fallthroughs', () => {
|
|
|
|
test('transition', () => {
|
|
|
|
expect(compile(`<transition><div/></transition>`).code)
|
|
|
|
.toMatchInlineSnapshot(`
|
|
|
|
"const { ssrRenderAttrs: _ssrRenderAttrs } = require(\\"vue/server-renderer\\")
|
|
|
|
|
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
|
|
|
_push(\`<div\${_ssrRenderAttrs(_attrs)}></div>\`)
|
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('keep-alive', () => {
|
|
|
|
expect(compile(`<keep-alive><foo/></keep-alive>`).code)
|
|
|
|
.toMatchInlineSnapshot(`
|
|
|
|
"const { resolveComponent: _resolveComponent } = require(\\"vue\\")
|
|
|
|
const { ssrRenderComponent: _ssrRenderComponent } = require(\\"vue/server-renderer\\")
|
|
|
|
|
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
|
|
|
|
|
|
|
_push(_ssrRenderComponent(_component_foo, _attrs, null, _parent))
|
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('should inject attrs if root with coomments', () => {
|
|
|
|
expect(compile(`<!--root--><transition><div/></transition>`).code)
|
|
|
|
.toMatchInlineSnapshot(`
|
|
|
|
"const { ssrRenderAttrs: _ssrRenderAttrs } = require(\\"vue/server-renderer\\")
|
|
|
|
|
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
|
|
|
_push(\`<!--[--><!--root--><div\${_ssrRenderAttrs(_attrs)}></div><!--]-->\`)
|
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('should not inject attrs if not root', () => {
|
|
|
|
expect(compile(`<div/><transition><div/></transition>`).code)
|
|
|
|
.toMatchInlineSnapshot(`
|
|
|
|
"
|
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
|
|
|
_push(\`<!--[--><div></div><div></div><!--]-->\`)
|
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
|
|
|
|
// #5352
|
|
|
|
test('should push marker string if is slot root', () => {
|
|
|
|
expect(
|
|
|
|
compile(`<foo><transition><div v-if="false"/></transition></foo>`)
|
|
|
|
.code
|
|
|
|
).toMatchInlineSnapshot(`
|
|
|
|
"const { resolveComponent: _resolveComponent, withCtx: _withCtx, openBlock: _openBlock, createBlock: _createBlock, createCommentVNode: _createCommentVNode, Transition: _Transition, createVNode: _createVNode } = require(\\"vue\\")
|
|
|
|
const { ssrRenderComponent: _ssrRenderComponent } = require(\\"vue/server-renderer\\")
|
2020-02-06 20:29:02 +00:00
|
|
|
|
2022-05-18 01:28:18 +00:00
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
|
|
|
|
|
|
|
_push(_ssrRenderComponent(_component_foo, _attrs, {
|
|
|
|
default: _withCtx((_, _push, _parent, _scopeId) => {
|
|
|
|
if (_push) {
|
|
|
|
_push(\`\`)
|
|
|
|
if (false) {
|
|
|
|
_push(\`<div\${_scopeId}></div>\`)
|
|
|
|
} else {
|
|
|
|
_push(\`<!---->\`)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return [
|
|
|
|
_createVNode(_Transition, null, {
|
|
|
|
default: _withCtx(() => [
|
|
|
|
false
|
|
|
|
? (_openBlock(), _createBlock(\\"div\\", { key: 0 }))
|
|
|
|
: _createCommentVNode(\\"v-if\\", true)
|
|
|
|
]),
|
|
|
|
_: 1 /* STABLE */
|
|
|
|
})
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
_: 1 /* STABLE */
|
|
|
|
}, _parent))
|
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
2020-02-26 19:59:53 +00:00
|
|
|
})
|
2020-02-06 17:05:53 +00:00
|
|
|
})
|
2022-02-04 00:58:28 +00:00
|
|
|
|
|
|
|
describe('custom directive', () => {
|
|
|
|
test('basic', () => {
|
|
|
|
expect(compile(`<foo v-xxx:x.y="z" />`).code).toMatchInlineSnapshot(`
|
|
|
|
"const { resolveComponent: _resolveComponent, resolveDirective: _resolveDirective, mergeProps: _mergeProps } = require(\\"vue\\")
|
|
|
|
const { ssrGetDirectiveProps: _ssrGetDirectiveProps, ssrRenderComponent: _ssrRenderComponent } = require(\\"vue/server-renderer\\")
|
|
|
|
|
|
|
|
return function ssrRender(_ctx, _push, _parent, _attrs) {
|
|
|
|
const _component_foo = _resolveComponent(\\"foo\\")
|
|
|
|
const _directive_xxx = _resolveDirective(\\"xxx\\")
|
|
|
|
|
|
|
|
_push(_ssrRenderComponent(_component_foo, _mergeProps(_attrs, _ssrGetDirectiveProps(_ctx, _directive_xxx, _ctx.z, \\"x\\", { y: true })), null, _parent))
|
|
|
|
}"
|
|
|
|
`)
|
|
|
|
})
|
|
|
|
})
|
2020-02-06 04:07:23 +00:00
|
|
|
})
|