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:
@@ -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)
|
||||
|
||||
32
packages/server-renderer/__tests__/webStream.spec.ts
Normal file
32
packages/server-renderer/__tests__/webStream.spec.ts
Normal 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><!--]-->`)
|
||||
})
|
||||
Reference in New Issue
Block a user