2020-03-23 20:54:28 +00:00
|
|
|
import { h } from '../src/h'
|
2019-08-29 20:47:00 +00:00
|
|
|
import { createVNode } from '../src/vnode'
|
2020-06-12 14:38:56 +00:00
|
|
|
import { RawSlots } from '../src/componentSlots'
|
2019-08-29 20:47:00 +00:00
|
|
|
|
|
|
|
// Since h is a thin layer on top of createVNode, we are only testing its
|
|
|
|
// own logic here. Details of vnode creation is tested in vnode.spec.ts.
|
2020-03-23 20:54:28 +00:00
|
|
|
describe('renderer: h', () => {
|
2019-08-29 20:47:00 +00:00
|
|
|
test('type only', () => {
|
|
|
|
expect(h('div')).toMatchObject(createVNode('div'))
|
|
|
|
})
|
|
|
|
|
|
|
|
test('type + props', () => {
|
|
|
|
expect(h('div', { id: 'foo' })).toMatchObject(
|
|
|
|
createVNode('div', { id: 'foo' })
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('type + omit props', () => {
|
|
|
|
// array
|
|
|
|
expect(h('div', ['foo'])).toMatchObject(createVNode('div', null, ['foo']))
|
|
|
|
// default slot
|
2019-10-10 14:17:16 +00:00
|
|
|
const Component = { template: '<br />' }
|
2019-08-29 20:47:00 +00:00
|
|
|
const slot = () => {}
|
2019-10-10 14:17:16 +00:00
|
|
|
expect(h(Component, slot)).toMatchObject(createVNode(Component, null, slot))
|
|
|
|
// single vnode
|
|
|
|
const vnode = h('div')
|
|
|
|
expect(h('div', vnode)).toMatchObject(createVNode('div', null, [vnode]))
|
2019-08-29 20:47:00 +00:00
|
|
|
// text
|
|
|
|
expect(h('div', 'foo')).toMatchObject(createVNode('div', null, 'foo'))
|
|
|
|
})
|
|
|
|
|
|
|
|
test('type + props + children', () => {
|
|
|
|
// array
|
|
|
|
expect(h('div', {}, ['foo'])).toMatchObject(createVNode('div', {}, ['foo']))
|
2020-06-12 14:38:56 +00:00
|
|
|
// slots
|
|
|
|
const slots = {} as RawSlots
|
|
|
|
expect(h('div', {}, slots)).toMatchObject(createVNode('div', {}, slots))
|
2019-10-10 14:17:16 +00:00
|
|
|
const Component = { template: '<br />' }
|
2020-06-12 14:38:56 +00:00
|
|
|
expect(h(Component, {}, slots)).toMatchObject(
|
|
|
|
createVNode(Component, {}, slots)
|
|
|
|
)
|
|
|
|
// default slot
|
2019-08-29 20:47:00 +00:00
|
|
|
const slot = () => {}
|
2019-10-10 14:17:16 +00:00
|
|
|
expect(h(Component, {}, slot)).toMatchObject(
|
|
|
|
createVNode(Component, {}, slot)
|
|
|
|
)
|
|
|
|
// single vnode
|
|
|
|
const vnode = h('div')
|
|
|
|
expect(h('div', {}, vnode)).toMatchObject(createVNode('div', {}, [vnode]))
|
2019-08-29 20:47:00 +00:00
|
|
|
// text
|
|
|
|
expect(h('div', {}, 'foo')).toMatchObject(createVNode('div', {}, 'foo'))
|
|
|
|
})
|
|
|
|
|
|
|
|
test('named slots with null props', () => {
|
2019-10-10 14:17:16 +00:00
|
|
|
const Component = { template: '<br />' }
|
2019-08-29 20:47:00 +00:00
|
|
|
const slot = () => {}
|
|
|
|
expect(
|
2019-10-10 14:17:16 +00:00
|
|
|
h(Component, null, {
|
2019-08-29 20:47:00 +00:00
|
|
|
foo: slot
|
|
|
|
})
|
|
|
|
).toMatchObject(
|
2019-10-10 14:17:16 +00:00
|
|
|
createVNode(Component, null, {
|
2019-08-29 20:47:00 +00:00
|
|
|
foo: slot
|
|
|
|
})
|
|
|
|
)
|
|
|
|
})
|
2020-08-22 01:54:33 +00:00
|
|
|
|
|
|
|
// for simple JSX compat
|
|
|
|
// note this signature is not supported in types; it's purely for usage with
|
|
|
|
// compiled code.
|
|
|
|
test('support variadic children', () => {
|
|
|
|
// @ts-ignore
|
|
|
|
const vnode = h('div', null, h('span'), h('span'))
|
|
|
|
expect(vnode.children).toMatchObject([
|
|
|
|
{
|
|
|
|
type: 'span'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'span'
|
|
|
|
}
|
|
|
|
])
|
|
|
|
})
|
2019-08-23 19:32:19 +00:00
|
|
|
})
|