test: test for h
This commit is contained in:
parent
ac625e03fe
commit
10bbf52c09
@ -1,3 +1,49 @@
|
|||||||
|
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('vdom: h', () => {
|
describe('vdom: h', () => {
|
||||||
test.todo('should work')
|
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
|
||||||
|
})
|
||||||
|
)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
Loading…
x
Reference in New Issue
Block a user