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:
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