test(runtime-dom): improve v-on system key modifiers test (#1597)

This commit is contained in:
motao 2020-07-19 10:55:39 +08:00 committed by GitHub
parent 61b02d8577
commit b8db7ab889
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -41,35 +41,39 @@ describe('runtime-dom: v-on directive', () => {
}) })
test('it should support key modifiers and system modifiers', () => { test('it should support key modifiers and system modifiers', () => {
const el = document.createElement('div') const keyNames = ["ctrl","shift","meta","alt"]
const fn = jest.fn()
// <div @keyup.ctrl.esc="test"/>
const nextValue = withKeys(withModifiers(fn, ['ctrl']), [
'esc',
'arrow-left'
])
patchEvent(el, 'onKeyup', null, nextValue, null)
triggerEvent(el, 'keyup', e => (e.key = 'a')) keyNames.forEach(keyName=>{
expect(fn).not.toBeCalled() const el = document.createElement('div')
const fn = jest.fn()
triggerEvent(el, 'keyup', e => { // <div @keyup[keyName].esc="test"/>
e.ctrlKey = false const nextValue = withKeys(withModifiers(fn, [keyName]), [
e.key = 'esc' 'esc',
}) 'arrow-left'
expect(fn).not.toBeCalled() ])
patchEvent(el, 'onKeyup', null, nextValue, null)
triggerEvent(el, 'keyup', e => {
e.ctrlKey = true triggerEvent(el, 'keyup', e => (e.key = 'a'))
e.key = 'Escape' expect(fn).not.toBeCalled()
})
expect(fn).toBeCalledTimes(1) triggerEvent(el, 'keyup', e => {
e[`${keyName}Key`] = false
triggerEvent(el, 'keyup', e => { e.key = 'esc'
e.ctrlKey = true })
e.key = 'ArrowLeft' expect(fn).not.toBeCalled()
})
expect(fn).toBeCalledTimes(2) triggerEvent(el, 'keyup', e => {
e[`${keyName}Key`] = true
e.key = 'Escape'
})
expect(fn).toBeCalledTimes(1)
triggerEvent(el, 'keyup', e => {
e[`${keyName}Key`] = true
e.key = 'ArrowLeft'
})
expect(fn).toBeCalledTimes(2)
});
}) })
test('it should support "exact" modifier', () => { test('it should support "exact" modifier', () => {