feat(server-renderer): decouple esm build from Node + improve stream API

- deprecate `renderToSTream`
- added `renderToNodeStream`
- added `renderToWebStream`
- added `renderToSimpleStream`

close #3467
close #3111
close #3460
This commit is contained in:
Evan You
2021-07-29 13:12:50 -04:00
parent 0affd4daf4
commit 08672222c6
7 changed files with 271 additions and 12 deletions

View File

@@ -24,7 +24,7 @@ import {
} from 'vue'
import { escapeHtml } from '@vue/shared'
import { renderToString } from '../src/renderToString'
import { renderToStream as _renderToStream } from '../src/renderToStream'
import { renderToNodeStream } from '../src/renderToStream'
import { ssrRenderSlot, SSRSlot } from '../src/helpers/ssrRenderSlot'
import { ssrRenderComponent } from '../src/helpers/ssrRenderComponent'
import { Readable } from 'stream'
@@ -46,7 +46,7 @@ const promisifyStream = (stream: Readable) => {
}
const renderToStream = (app: any, context?: any) =>
promisifyStream(_renderToStream(app, context))
promisifyStream(renderToNodeStream(app, context))
// we run the same tests twice, once for renderToString, once for renderToStream
testRender(`renderToString`, renderToString)

View File

@@ -0,0 +1,32 @@
/**
* @jest-environment node
*/
import { createApp, h, defineAsyncComponent } from 'vue'
import { ReadableStream } from 'stream/web'
import { renderToWebStream } from '../src'
test('should work', async () => {
const Async = defineAsyncComponent(() =>
Promise.resolve({
render: () => h('div', 'async')
})
)
const App = {
render: () => [h('div', 'parent'), h(Async)]
}
const stream = renderToWebStream(createApp(App), {}, ReadableStream)
const reader = stream.getReader()
let res = ''
await reader.read().then(function read({ done, value }): any {
if (!done) {
res += value
return reader.read().then(read)
}
})
expect(res).toBe(`<!--[--><div>parent</div><div>async</div><!--]-->`)
})