vue2/test/ssr/ssr-stream.spec.js

80 lines
2.1 KiB
JavaScript
Raw Normal View History

2016-04-26 07:10:33 +08:00
import Vue from '../../dist/vue.common.js'
2016-06-25 12:05:39 +08:00
import { createRenderer } from '../../packages/vue-server-renderer'
const { renderToStream } = createRenderer()
2016-04-26 07:10:33 +08:00
describe('SSR: renderToStream', () => {
it('should render to a stream', done => {
const stream = renderToStream(new Vue({
2016-04-26 07:10:33 +08:00
template: `
<div>
<p class="hi">yoyo</p>
<div id="ho" :class="[testClass, { red: isRed }]"></div>
2016-04-26 07:10:33 +08:00
<span>{{ test }}</span>
<input :value="test">
<b-comp></b-comp>
<c-comp></c-comp>
2016-04-26 07:10:33 +08:00
</div>
`,
data: {
test: 'hi',
isRed: true,
testClass: 'a'
2016-04-26 07:10:33 +08:00
},
components: {
bComp (resolve) {
return resolve({
render () {
return this.$createElement('test-async-2')
},
components: {
testAsync2 (resolve) {
return resolve({
created () { this.$parent.$parent.testClass = 'b' },
render () {
return this.$createElement('div', { class: [this.$parent.$parent.testClass] }, 'test')
}
})
}
}
})
},
cComp: {
render () {
return this.$createElement('div', { class: [this.$parent.testClass] }, 'test')
2016-04-26 07:10:33 +08:00
}
}
}
}))
2016-04-26 07:10:33 +08:00
let res = ''
stream.on('data', chunk => {
res += chunk
})
stream.on('end', () => {
expect(res).toContain(
'<div server-rendered="true">' +
'<p class="hi">yoyo</p> ' +
'<div id="ho" class="a red"></div> ' +
'<span>hi</span> ' +
'<input value="hi"> ' +
'<div class="b">test</div> ' +
'<div class="b">test</div>' +
'</div>'
)
2016-04-26 07:10:33 +08:00
done()
})
})
2016-05-12 14:49:11 +08:00
it('should catch error', done => {
const stream = renderToStream(new Vue({
render () {
throw new Error('oops')
}
}))
stream.on('error', err => {
expect(err.toString()).toMatch(/oops/)
done()
})
stream.on('data', _ => _)
})
2016-04-26 07:10:33 +08:00
})