vue3-core/packages/compiler-ssr/__tests__/ssrComponent.spec.ts

212 lines
6.7 KiB
TypeScript
Raw Normal View History

2020-02-06 12:07:23 +08:00
import { compile } from '../src'
describe('ssr: components', () => {
test('basic', () => {
expect(compile(`<foo id="a" :prop="b" />`).code).toMatchInlineSnapshot(`
"const { resolveComponent } = require(\\"vue\\")
2020-02-07 01:09:09 +08:00
const { _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
2020-02-06 12:07:23 +08:00
return function ssrRender(_ctx, _push, _parent) {
const _component_foo = resolveComponent(\\"foo\\")
_push(_ssrRenderComponent(_component_foo, {
2020-02-06 12:07:23 +08:00
id: \\"a\\",
prop: _ctx.b
}, null, _parent))
2020-02-06 12:07:23 +08:00
}"
`)
})
test('dynamic component', () => {
expect(compile(`<component is="foo" prop="b" />`).code)
.toMatchInlineSnapshot(`
"const { resolveComponent } = require(\\"vue\\")
2020-02-07 01:09:09 +08:00
const { _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
2020-02-06 12:07:23 +08:00
return function ssrRender(_ctx, _push, _parent) {
const _component_foo = resolveComponent(\\"foo\\")
_push(_ssrRenderComponent(_component_foo, { prop: \\"b\\" }, null, _parent))
2020-02-06 12:07:23 +08:00
}"
`)
expect(compile(`<compoonent :is="foo" prop="b" />`).code)
.toMatchInlineSnapshot(`
"const { resolveComponent } = require(\\"vue\\")
2020-02-07 01:09:09 +08:00
const { _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
2020-02-06 12:07:23 +08:00
return function ssrRender(_ctx, _push, _parent) {
const _component_compoonent = resolveComponent(\\"compoonent\\")
_push(_ssrRenderComponent(_component_compoonent, {
2020-02-06 12:07:23 +08:00
is: _ctx.foo,
prop: \\"b\\"
}, null, _parent))
2020-02-06 12:07:23 +08:00
}"
`)
})
2020-02-07 01:05:53 +08:00
describe('slots', () => {
test('implicit default slot', () => {
expect(compile(`<foo>hello<div/></foo>`).code).toMatchInlineSnapshot(`
"const { resolveComponent } = require(\\"vue\\")
2020-02-07 01:09:09 +08:00
const { _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
2020-02-07 01:05:53 +08:00
return function ssrRender(_ctx, _push, _parent) {
const _component_foo = resolveComponent(\\"foo\\")
_push(_ssrRenderComponent(_component_foo, null, {
2020-02-07 06:45:34 +08:00
default: (_, _push, _parent, _scopeId) => {
if (_scopeId) {
_push(\`hello<div \${_scopeId}></div>\`)
} else {
_push(\`hello<div></div>\`)
}
2020-02-07 01:05:53 +08:00
},
_compiled: true
}, _parent))
2020-02-07 01:05:53 +08:00
}"
`)
})
test('explicit default slot', () => {
expect(compile(`<foo v-slot="{ msg }">{{ msg + outer }}</foo>`).code)
.toMatchInlineSnapshot(`
"const { resolveComponent } = require(\\"vue\\")
2020-02-07 01:09:09 +08:00
const { _ssrRenderComponent, _ssrInterpolate } = require(\\"@vue/server-renderer\\")
2020-02-07 01:05:53 +08:00
return function ssrRender(_ctx, _push, _parent) {
const _component_foo = resolveComponent(\\"foo\\")
_push(_ssrRenderComponent(_component_foo, null, {
2020-02-07 06:45:34 +08:00
default: ({ msg }, _push, _parent, _scopeId) => {
2020-02-07 01:09:09 +08:00
_push(\`\${_ssrInterpolate(msg + _ctx.outer)}\`)
2020-02-07 01:05:53 +08:00
},
_compiled: true
}, _parent))
2020-02-07 01:05:53 +08:00
}"
`)
})
test('named slots', () => {
expect(
compile(`<foo>
<template v-slot>foo</template>
<template v-slot:named>bar</template>
</foo>`).code
).toMatchInlineSnapshot(`
"const { resolveComponent } = require(\\"vue\\")
2020-02-07 01:09:09 +08:00
const { _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
2020-02-07 01:05:53 +08:00
return function ssrRender(_ctx, _push, _parent) {
const _component_foo = resolveComponent(\\"foo\\")
_push(_ssrRenderComponent(_component_foo, null, {
2020-02-07 06:45:34 +08:00
default: (_, _push, _parent, _scopeId) => {
2020-02-07 01:05:53 +08:00
_push(\`foo\`)
},
2020-02-07 06:45:34 +08:00
named: (_, _push, _parent, _scopeId) => {
2020-02-07 01:05:53 +08:00
_push(\`bar\`)
},
_compiled: true
}, _parent))
2020-02-07 01:05:53 +08:00
}"
`)
})
test('v-if slot', () => {
expect(
compile(`<foo>
<template v-slot:named v-if="ok">foo</template>
</foo>`).code
).toMatchInlineSnapshot(`
"const { resolveComponent, createSlots } = require(\\"vue\\")
2020-02-07 01:09:09 +08:00
const { _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
2020-02-07 01:05:53 +08:00
return function ssrRender(_ctx, _push, _parent) {
const _component_foo = resolveComponent(\\"foo\\")
_push(_ssrRenderComponent(_component_foo, null, createSlots({ _compiled: true }, [
2020-02-07 01:05:53 +08:00
(_ctx.ok)
? {
name: \\"named\\",
2020-02-07 06:45:34 +08:00
fn: (_, _push, _parent, _scopeId) => {
2020-02-07 01:05:53 +08:00
_push(\`foo\`)
}
}
: undefined
]), _parent))
2020-02-07 01:05:53 +08: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(`
"const { resolveComponent, renderList, createSlots } = require(\\"vue\\")
2020-02-07 01:09:09 +08:00
const { _ssrRenderComponent, _ssrInterpolate } = require(\\"@vue/server-renderer\\")
2020-02-07 01:05:53 +08:00
return function ssrRender(_ctx, _push, _parent) {
const _component_foo = resolveComponent(\\"foo\\")
_push(_ssrRenderComponent(_component_foo, null, createSlots({ _compiled: true }, [
2020-02-07 01:05:53 +08:00
renderList(_ctx.names, (key) => {
return {
name: key,
2020-02-07 06:45:34 +08:00
fn: ({ msg }, _push, _parent, _scopeId) => {
2020-02-07 01:09:09 +08:00
_push(\`\${_ssrInterpolate(msg + key + _ctx.bar)}\`)
2020-02-07 01:05:53 +08:00
}
}
})
]), _parent))
2020-02-07 01:05:53 +08:00
}"
`)
})
test('built-in fallthroughs', () => {
// no fragment
expect(compile(`<transition><div/></transition>`).code)
.toMatchInlineSnapshot(`
"
return function ssrRender(_ctx, _push, _parent) {
_push(\`<div></div>\`)
}"
`)
// wrap with fragment
expect(compile(`<transition-group><div/></transition-group>`).code)
.toMatchInlineSnapshot(`
"
return function ssrRender(_ctx, _push, _parent) {
_push(\`<!----><div></div><!---->\`)
}"
`)
// no fragment
expect(compile(`<keep-alive><foo/></keep-alive>`).code)
.toMatchInlineSnapshot(`
"const { resolveComponent } = require(\\"vue\\")
const { _ssrRenderComponent } = require(\\"@vue/server-renderer\\")
return function ssrRender(_ctx, _push, _parent) {
const _component_foo = resolveComponent(\\"foo\\")
_push(_ssrRenderComponent(_component_foo, null, null, _parent))
}"
`)
// wrap with fragment
expect(compile(`<suspense><div/></suspense>`).code)
.toMatchInlineSnapshot(`
"
return function ssrRender(_ctx, _push, _parent) {
_push(\`<!----><div></div><!---->\`)
}"
`)
})
2020-02-07 01:05:53 +08:00
})
2020-02-06 12:07:23 +08:00
})