2020-02-03 22:47:06 +00:00
|
|
|
import { compile } from '../src'
|
2020-02-03 16:46:14 +00:00
|
|
|
import { getCompiledString } from './utils'
|
|
|
|
|
2020-02-03 20:51:41 +00:00
|
|
|
describe('ssr: text', () => {
|
2020-02-03 16:46:14 +00:00
|
|
|
test('static text', () => {
|
|
|
|
expect(getCompiledString(`foo`)).toMatchInlineSnapshot(`"\`foo\`"`)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('static text escape', () => {
|
|
|
|
expect(getCompiledString(`<foo>`)).toMatchInlineSnapshot(
|
|
|
|
`"\`<foo>\`"`
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('nested elements with static text', () => {
|
|
|
|
expect(
|
|
|
|
getCompiledString(`<div><span>hello</span><span>bye</span></div>`)
|
|
|
|
).toMatchInlineSnapshot(
|
|
|
|
`"\`<div><span>hello</span><span>bye</span></div>\`"`
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('interpolation', () => {
|
2020-02-03 22:47:06 +00:00
|
|
|
expect(compile(`foo {{ bar }} baz`).code).toMatchInlineSnapshot(`
|
2020-02-08 00:04:55 +00:00
|
|
|
"const { ssrInterpolate: _ssrInterpolate } = require(\\"@vue/server-renderer\\")
|
2020-02-03 22:47:06 +00:00
|
|
|
|
|
|
|
return function ssrRender(_ctx, _push, _parent) {
|
2020-02-06 17:09:09 +00:00
|
|
|
_push(\`foo \${_ssrInterpolate(_ctx.bar)} baz\`)
|
2020-02-03 22:47:06 +00:00
|
|
|
}"
|
|
|
|
`)
|
2020-02-03 16:46:14 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
test('nested elements with interpolation', () => {
|
|
|
|
expect(
|
2020-02-03 22:47:06 +00:00
|
|
|
compile(`<div><span>{{ foo }} bar</span><span>baz {{ qux }}</span></div>`)
|
|
|
|
.code
|
|
|
|
).toMatchInlineSnapshot(`
|
2020-02-08 00:04:55 +00:00
|
|
|
"const { ssrInterpolate: _ssrInterpolate } = require(\\"@vue/server-renderer\\")
|
2020-02-03 22:47:06 +00:00
|
|
|
|
|
|
|
return function ssrRender(_ctx, _push, _parent) {
|
2020-02-04 21:47:12 +00:00
|
|
|
_push(\`<div><span>\${
|
2020-02-06 17:09:09 +00:00
|
|
|
_ssrInterpolate(_ctx.foo)
|
2020-02-04 21:47:12 +00:00
|
|
|
} bar</span><span>baz \${
|
2020-02-06 17:09:09 +00:00
|
|
|
_ssrInterpolate(_ctx.qux)
|
2020-02-04 21:47:12 +00:00
|
|
|
}</span></div>\`)
|
2020-02-03 22:47:06 +00:00
|
|
|
}"
|
|
|
|
`)
|
2020-02-03 16:46:14 +00:00
|
|
|
})
|
|
|
|
})
|