| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- import { h } from '../src/h'
- import { createVNode } from '../src/vnode'
- // 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.
- describe('renderer: h', () => {
- 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
- const slot = () => {}
- expect(h('div', slot)).toMatchObject(createVNode('div', null, slot))
- // text
- expect(h('div', 'foo')).toMatchObject(createVNode('div', null, 'foo'))
- })
- test('type + props + children', () => {
- // array
- expect(h('div', {}, ['foo'])).toMatchObject(createVNode('div', {}, ['foo']))
- // default slot
- const slot = () => {}
- expect(h('div', {}, slot)).toMatchObject(createVNode('div', {}, slot))
- // text
- expect(h('div', {}, 'foo')).toMatchObject(createVNode('div', {}, 'foo'))
- })
- test('named slots with null props', () => {
- const slot = () => {}
- expect(
- h('div', null, {
- foo: slot
- })
- ).toMatchObject(
- createVNode('div', null, {
- foo: slot
- })
- )
- })
- })
|