import { parse } from 'compiler/parser/index' import { optimize } from 'compiler/optimizer' import { generate } from 'compiler/codegen' import { isObject } from 'shared/util' import { isReservedTag } from 'web/util/index' import { baseOptions } from 'web/compiler/index' function assertCodegen (template, generatedCode, ...args) { let staticRenderFnCodes = [] let generateOptions = baseOptions let proc = null let len = args.length while (len--) { const arg = args[len] if (Array.isArray(arg)) { staticRenderFnCodes = arg } else if (isObject(arg)) { generateOptions = arg } else if (typeof arg === 'function') { proc = arg } } const ast = parse(template, baseOptions) optimize(ast, baseOptions) proc && proc(ast) const res = generate(ast, generateOptions) expect(res.render).toBe(generatedCode) expect(res.staticRenderFns).toEqual(staticRenderFnCodes) } /* eslint-disable quotes */ describe('codegen', () => { it('generate directive', () => { assertCodegen( '
', `with(this){return _h('p',{directives:[{name:"custom1",value:(value1),expression:"value1",arg:"arg1",modifiers:{"modifire":true}},{name:"custom2",arg:"arg1"}]})}` ) }) it('generate v-for directive', () => { assertCodegen( '
', `with(this){return _l((items),function(item){return _h('li',{key:item.uid})})}` ) // iterator syntax assertCodegen( '', `with(this){return _l((items),function(item,i){return _h('li')})}` ) assertCodegen( '', `with(this){return _l((items),function(item,key,index){return _h('li')})}` ) }) it('generate v-if directive', () => { assertCodegen( 'hello
', `with(this){return (show)?_h('p',["hello"]):_e()}` ) }) it('generate v-else directive', () => { assertCodegen( 'hello
world
{{hello}}
', `with(this){return [_h('p',[_s(hello)])]}` ) }) it('generate single slot', () => { assertCodegen( 'hello world
', `with(this){return _h('p',{slot:"one"},["hello world"])}` ) }) it('generate class binding', () => { // static assertCodegen( 'hello world
', 'with(this){return _m(0)}', [`with(this){return _h('p',{staticClass:"class1"},["hello world"])}`] ) // dynamic assertCodegen( 'hello world
', `with(this){return _h('p',{class:class1},["hello world"])}` ) }) it('generate style binding', () => { assertCodegen( 'hello world
', `with(this){return _h('p',{style:(error)},["hello world"])}` ) }) it('generate v-show directive', () => { assertCodegen( 'hello world
', `with(this){return _h('p',{directives:[{name:"show",value:(shown),expression:"shown"}]},["hello world"])}` ) }) it('generate DOM props with v-bind directive', () => { assertCodegen( '',
`with(this){return _h('p',{domProps:{"value":msg}})}`
)
})
it('generate attrs with v-bind directive', () => {
assertCodegen(
'',
`with(this){return _h('input',{attrs:{"name":field1}})}`
)
})
it('generate static attrs', () => {
assertCodegen(
'',
`with(this){return _m(0)}`,
[`with(this){return _h('input',{attrs:{"name":"field1"}})}`]
)
})
it('generate events with v-on directive', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":onInput}})}`
)
})
it('generate events with keycode', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){if($event.keyCode!==13)return;onInput($event)}}})}`
)
// multiple keycodes (delete)
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){if($event.keyCode!==8&&$event.keyCode!==46)return;onInput($event)}}})}`
)
// multiple keycodes (chained)
assertCodegen(
'',
`with(this){return _h('input',{on:{"keydown":function($event){if($event.keyCode!==13&&$event.keyCode!==8&&$event.keyCode!==46)return;onInput($event)}}})}`
)
// number keycode
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){if($event.keyCode!==13)return;onInput($event)}}})}`
)
// custom keycode
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){if($event.keyCode!==_k("custom"))return;onInput($event)}}})}`
)
})
it('generate events with modifiers', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){$event.stopPropagation();onInput($event)}}})}`
)
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){$event.preventDefault();onInput($event)}}})}`
)
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){if($event.target !== $event.currentTarget)return;onInput($event)}}})}`
)
})
it('generate events with multiple modifers', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){$event.stopPropagation();$event.preventDefault();if($event.target !== $event.currentTarget)return;onInput($event)}}})}`
)
})
it('generate events with capture modifier', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"!input":function($event){onInput($event)}}})}`
)
})
it('generate events with inline statement', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function($event){curent++}}})}`
)
})
// #3893
it('should not treat handler with unexpected whitespace as inline statement', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"input": onInput }})}`
)
})
it('generate unhandled events', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":function(){}}})}`,
ast => {
ast.events.input = undefined
}
)
})
it('generate multiple event handlers', () => {
assertCodegen(
'',
`with(this){return _h('input',{on:{"input":[function($event){curent++},onInput]}})}`
)
})
it('generate component', () => {
assertCodegen(
'
hello world
hello world
', `with(this){return (show)?_h('p',["hello world"]):_e()}`, { isReservedTag } ) }) }) /* eslint-enable quotes */