Skip to content

Commit

Permalink
fix: wrapper.element with nested multiple roots
Browse files Browse the repository at this point in the history
  • Loading branch information
freakzlike committed Apr 29, 2022
1 parent 72832a6 commit fcae60f
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 6 deletions.
2 changes: 1 addition & 1 deletion src/vueWrapper.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ export class VueWrapper<
// Recursive check subtree for nested root elements
// <template>
// <WithMultipleRoots />
// </template
// </template>
const checkTree = (subTree: VNode): boolean => {
// if the subtree is an array of children, we have multiple root nodes
if (subTree.shapeFlag === ShapeFlags.ARRAY_CHILDREN) return true
Expand Down
71 changes: 66 additions & 5 deletions tests/element.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,15 @@ import { defineComponent, h } from 'vue'

import { mount } from '../src'

const MultiRootText = defineComponent({
render: () => [h('div', {}, 'foo'), h('div', {}, 'bar'), h('div', {}, 'baz')]
})
const ReturnSlot = defineComponent({
render() {
return this.$slots.default!({})
}
})

describe('element', () => {
it('returns element when mounting single root node', () => {
const Component = defineComponent({
Expand All @@ -16,14 +25,66 @@ describe('element', () => {
})

it('returns the VTU root element when mounting multiple root nodes', () => {
const Component = defineComponent({
render() {
return [h('div', {}, 'foo'), h('div', {}, 'bar'), h('div', {}, 'baz')]
}
const wrapper = mount(MultiRootText)

expect(wrapper.element.innerHTML).toBe(
'<div>foo</div><div>bar</div><div>baz</div>'
)
})

it('returns correct element for root component with multiple roots', () => {
const Parent = defineComponent({
components: { MultiRootText },
template: '<MultiRootText/>'
})

const wrapper = mount(Component)
const wrapper = mount(Parent)

expect(wrapper.findComponent(MultiRootText).text()).toBe('foobarbaz')
expect(wrapper.text()).toBe('foobarbaz')
})

it('returns correct element for root slot', () => {
const Parent = defineComponent({
components: { ReturnSlot },
template: `
<ReturnSlot>
<div>foo</div>
<div>bar</div>
<div>baz</div>
</ReturnSlot>`
})

const wrapper = mount(Parent)
expect(wrapper.element.innerHTML).toBe(
'<div>foo</div><div>bar</div><div>baz</div>'
)
})

it('should return element for multi root functional component', () => {
const Foo = () => h(MultiRootText)
const wrapper = mount(Foo)

expect(wrapper.element.innerHTML).toBe(
'<div>foo</div><div>bar</div><div>baz</div>'
)
})

it('returns correct element for root slot with functional component', () => {
const wrapper = mount(() =>
h(ReturnSlot, {}, () => [
h('div', {}, 'foo'),
h('div', {}, 'bar'),
h('div', {}, 'baz')
])
)
expect(wrapper.element.innerHTML).toBe(
'<div>foo</div><div>bar</div><div>baz</div>'
)
})

it('returns correct element for root slot with nested component', () => {
const wrapper = mount(() => h(ReturnSlot, {}, () => h(MultiRootText)))
expect(wrapper.element.innerHTML).toBe(
'<div>foo</div><div>bar</div><div>baz</div>'
)
Expand Down

0 comments on commit fcae60f

Please sign in to comment.