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

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

172 lines
5.4 KiB
TypeScript
Raw Normal View History

2020-02-07 06:45:34 +08:00
import { compile } from '../src'
const scopeId = 'data-v-xxxxxxx'
describe('ssr: scopeId', () => {
test('basic', () => {
expect(
compile(`<div><span>hello</span></div>`, {
scopeId,
mode: 'module',
2020-02-07 06:45:34 +08:00
}).code,
).toMatchInlineSnapshot(`
2023-12-05 10:47:38 +08:00
"import { ssrRenderAttrs as _ssrRenderAttrs } from "vue/server-renderer"
export function ssrRender(_ctx, _push, _parent, _attrs) {
_push(\`<div\${_ssrRenderAttrs(_attrs)} data-v-xxxxxxx><span data-v-xxxxxxx>hello</span></div>\`)
}"
2020-02-07 06:45:34 +08:00
`)
})
test('inside slots (only text)', () => {
// should have no branching inside slot
expect(
compile(`<foo>foo</foo>`, {
scopeId,
mode: 'module',
2020-02-07 06:45:34 +08:00
}).code,
).toMatchInlineSnapshot(`
2023-12-05 10:47:38 +08:00
"import { resolveComponent as _resolveComponent, withCtx as _withCtx, createTextVNode as _createTextVNode } from "vue"
import { ssrRenderComponent as _ssrRenderComponent } from "vue/server-renderer"
2020-02-07 06:45:34 +08:00
export function ssrRender(_ctx, _push, _parent, _attrs) {
2023-12-05 10:47:38 +08:00
const _component_foo = _resolveComponent("foo")
2020-02-07 06:45:34 +08:00
_push(_ssrRenderComponent(_component_foo, _attrs, {
default: _withCtx((_, _push, _parent, _scopeId) => {
2020-02-07 14:06:51 +08:00
if (_push) {
_push(\`foo\`)
} else {
return [
2023-12-05 10:47:38 +08:00
_createTextVNode("foo")
2020-02-07 14:06:51 +08:00
]
}
}),
2020-12-01 04:11:58 +08:00
_: 1 /* STABLE */
}, _parent))
}"
2020-02-07 06:45:34 +08:00
`)
})
test('inside slots (with elements)', () => {
expect(
compile(`<foo><span>hello</span></foo>`, {
scopeId,
mode: 'module',
2020-02-07 06:45:34 +08:00
}).code,
).toMatchInlineSnapshot(`
2023-12-05 10:47:38 +08:00
"import { resolveComponent as _resolveComponent, withCtx as _withCtx, createVNode as _createVNode } from "vue"
import { ssrRenderComponent as _ssrRenderComponent } from "vue/server-renderer"
2020-02-07 06:45:34 +08:00
export function ssrRender(_ctx, _push, _parent, _attrs) {
2023-12-05 10:47:38 +08:00
const _component_foo = _resolveComponent("foo")
2020-02-07 06:45:34 +08:00
_push(_ssrRenderComponent(_component_foo, _attrs, {
default: _withCtx((_, _push, _parent, _scopeId) => {
2020-02-07 14:06:51 +08:00
if (_push) {
_push(\`<span data-v-xxxxxxx\${_scopeId}>hello</span>\`)
2020-02-07 06:45:34 +08:00
} else {
2020-02-07 14:06:51 +08:00
return [
2023-12-05 10:47:38 +08:00
_createVNode("span", null, "hello")
2020-02-07 14:06:51 +08:00
]
2020-02-07 06:45:34 +08:00
}
}),
2020-12-01 04:11:58 +08:00
_: 1 /* STABLE */
}, _parent))
}"
2020-02-07 06:45:34 +08:00
`)
})
test('nested slots', () => {
expect(
compile(`<foo><span>hello</span><bar><span/></bar></foo>`, {
scopeId,
mode: 'module',
2020-02-07 06:45:34 +08:00
}).code,
).toMatchInlineSnapshot(`
2023-12-05 10:47:38 +08:00
"import { resolveComponent as _resolveComponent, withCtx as _withCtx, createVNode as _createVNode } from "vue"
import { ssrRenderComponent as _ssrRenderComponent } from "vue/server-renderer"
2020-02-07 06:45:34 +08:00
export function ssrRender(_ctx, _push, _parent, _attrs) {
2023-12-05 10:47:38 +08:00
const _component_foo = _resolveComponent("foo")
const _component_bar = _resolveComponent("bar")
2020-02-07 06:45:34 +08:00
_push(_ssrRenderComponent(_component_foo, _attrs, {
default: _withCtx((_, _push, _parent, _scopeId) => {
2020-02-07 14:06:51 +08:00
if (_push) {
_push(\`<span data-v-xxxxxxx\${_scopeId}>hello</span>\`)
_push(_ssrRenderComponent(_component_bar, null, {
default: _withCtx((_, _push, _parent, _scopeId) => {
2020-02-07 14:06:51 +08:00
if (_push) {
_push(\`<span data-v-xxxxxxx\${_scopeId}></span>\`)
2020-02-07 06:45:34 +08:00
} else {
2020-02-07 14:06:51 +08:00
return [
2023-12-05 10:47:38 +08:00
_createVNode("span")
2020-02-07 14:06:51 +08:00
]
2020-02-07 06:45:34 +08:00
}
}),
2020-12-01 04:11:58 +08:00
_: 1 /* STABLE */
}, _parent, _scopeId))
2020-02-07 06:45:34 +08:00
} else {
2020-02-07 14:06:51 +08:00
return [
2023-12-05 10:47:38 +08:00
_createVNode("span", null, "hello"),
_createVNode(_component_bar, null, {
default: _withCtx(() => [
2023-12-05 10:47:38 +08:00
_createVNode("span")
]),
2020-12-01 04:11:58 +08:00
_: 1 /* STABLE */
2020-02-07 14:06:51 +08:00
})
]
2020-02-07 06:45:34 +08:00
}
}),
2020-12-01 04:11:58 +08:00
_: 1 /* STABLE */
}, _parent))
}"
2020-02-07 06:45:34 +08:00
`)
})
// #7554
test('scopeId is correctly transform to scope attribute of transition-group ', () => {
expect(
compile(
`<transition-group tag="div" class="red"><span>hello</span></transition-group>`,
{
scopeId,
mode: 'module',
},
).code,
).toMatchInlineSnapshot(`
2023-12-05 10:47:38 +08:00
"import { mergeProps as _mergeProps } from "vue"
import { ssrRenderAttrs as _ssrRenderAttrs } from "vue/server-renderer"
export function ssrRender(_ctx, _push, _parent, _attrs) {
2023-12-05 10:47:38 +08:00
_push(\`<div\${_ssrRenderAttrs(_mergeProps({ class: "red" }, _attrs))} data-v-xxxxxxx><span data-v-xxxxxxx>hello</span></div>\`)
}"
`)
// with dynamic tag
expect(
compile(
`<transition-group :tag="someTag" class="red"><span>hello</span></transition-group>`,
{
scopeId,
mode: 'module',
},
).code,
).toMatchInlineSnapshot(`
2023-12-05 10:47:38 +08:00
"import { mergeProps as _mergeProps } from "vue"
import { ssrRenderAttrs as _ssrRenderAttrs } from "vue/server-renderer"
export function ssrRender(_ctx, _push, _parent, _attrs) {
_push(\`<\${
_ctx.someTag
}\${
2023-12-05 10:47:38 +08:00
_ssrRenderAttrs(_mergeProps({ class: "red" }, _attrs))
} data-v-xxxxxxx><span data-v-xxxxxxx>hello</span></\${
_ctx.someTag
}>\`)
}"
`)
})
2020-02-07 06:45:34 +08:00
})