2020-03-09 21:08:05 +00:00
|
|
|
import {
|
|
|
|
h,
|
|
|
|
render,
|
|
|
|
nodeOps,
|
|
|
|
TestElement,
|
|
|
|
serializeInner as inner
|
|
|
|
} from '@vue/runtime-test'
|
|
|
|
|
2019-08-29 20:56:31 +00:00
|
|
|
describe('renderer: element', () => {
|
2020-03-09 21:08:05 +00:00
|
|
|
let root: TestElement
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
root = nodeOps.createElement('div')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should create an element', () => {
|
|
|
|
render(h('div'), root)
|
|
|
|
expect(inner(root)).toBe('<div></div>')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should create an element with props', () => {
|
|
|
|
render(h('div', { id: 'foo', class: 'bar' }), root)
|
|
|
|
expect(inner(root)).toBe('<div id="foo" class="bar"></div>')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should create an element with direct text children', () => {
|
|
|
|
render(h('div', ['foo', ' ', 'bar']), root)
|
|
|
|
expect(inner(root)).toBe('<div>foo bar</div>')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should create an element with direct text children and props', () => {
|
|
|
|
render(h('div', { id: 'foo' }, ['bar']), root)
|
|
|
|
expect(inner(root)).toBe('<div id="foo">bar</div>')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should update an element tag which is already mounted', () => {
|
|
|
|
render(h('div', ['foo']), root)
|
|
|
|
expect(inner(root)).toBe('<div>foo</div>')
|
2019-08-22 02:00:48 +00:00
|
|
|
|
2020-03-09 21:08:05 +00:00
|
|
|
render(h('span', ['foo']), root)
|
|
|
|
expect(inner(root)).toBe('<span>foo</span>')
|
|
|
|
})
|
2019-08-22 02:00:48 +00:00
|
|
|
|
2020-03-09 21:08:05 +00:00
|
|
|
it('should update element props which is already mounted', () => {
|
|
|
|
render(h('div', { id: 'bar' }, ['foo']), root)
|
|
|
|
expect(inner(root)).toBe('<div id="bar">foo</div>')
|
2019-08-22 21:13:25 +00:00
|
|
|
|
2020-03-09 21:08:05 +00:00
|
|
|
render(h('div', { id: 'baz', class: 'bar' }, ['foo']), root)
|
|
|
|
expect(inner(root)).toBe('<div id="baz" class="bar">foo</div>')
|
|
|
|
})
|
2019-08-22 02:00:48 +00:00
|
|
|
})
|