element-plus/packages/dropdown/__tests__/dropdown.spec.ts

271 lines
9.0 KiB
TypeScript
Raw Normal View History

2020-08-28 11:44:04 +08:00
import { mount } from '@vue/test-utils'
import { eventKeys } from '@element-plus/utils/aria'
2020-09-02 17:44:14 +08:00
import { sleep } from '@element-plus/test-utils'
2020-08-28 11:44:04 +08:00
import Dropdown from '../src/dropdown.vue'
import DropdownItem from '../src/dropdown-item.vue'
import DropdownMenu from '../src/dropdown-menu.vue'
2020-09-03 13:12:44 +08:00
const TIMEOUT = 250
2020-08-28 11:44:04 +08:00
const MOUSE_ENTER_EVENT = 'mouseenter'
const MOUSE_LEAVE_EVENT = 'mouseleave'
const CLICK = 'click'
const _mount = (template: string, data, otherObj?) => mount({
components: {
[Dropdown.name]: Dropdown,
[DropdownItem.name]: DropdownItem,
[DropdownMenu.name]: DropdownMenu,
},
template,
data,
...otherObj,
})
describe('Dropdown', () => {
test('create', async () => {
const wrapper = _mount(
`
<el-dropdown ref="b" placement="right">
<span class="el-dropdown-link" ref="a">
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item>Apple</el-dropdown-item>
<el-dropdown-item>Orange</el-dropdown-item>
<el-dropdown-item>Cherry</el-dropdown-item>
<el-dropdown-item disabled>Peach</el-dropdown-item>
<el-dropdown-item divided>Pear</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
`,
() => ({}),
)
const content = wrapper.findComponent({ ref: 'b' }).vm.$refs.popper as any
const triggerElm = wrapper.find('.el-dropdown-link')
expect(content.value).toBe(false)
await triggerElm.trigger(MOUSE_ENTER_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(content.value).toBe(true)
await triggerElm.trigger(MOUSE_LEAVE_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(content.value).toBe(false)
})
test('menu click', async () => {
const wrapper = _mount(
`
<el-dropdown ref="b" @command="commandHandler" placement="right">
<span class="el-dropdown-link" ref="a">
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item command="a">Apple</el-dropdown-item>
<el-dropdown-item command="b">Orange</el-dropdown-item>
<el-dropdown-item ref="c" :command="myCommandObject">Cherry</el-dropdown-item>
<el-dropdown-item command="d">Peach</el-dropdown-item>
<el-dropdown-item command="e">Pear</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
`,
() => ({
myCommandObject: { name: 'CommandC' },
name: '',
}),
{
methods: {
commandHandler(command) {
this.name = command.name
},
},
},
)
// const content = wrapper.findComponent({ ref: 'b' }).vm.$refs.popper as any
const triggerElm = wrapper.find('.el-dropdown-link')
await triggerElm.trigger(MOUSE_ENTER_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
await wrapper.findComponent({ ref: 'c' }).trigger('click')
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect((wrapper.vm as any).name).toBe('CommandC')
})
test('trigger', async () => {
const wrapper = _mount(
`
<el-dropdown trigger="click" ref="b" placement="right">
<span class="el-dropdown-link" ref="a">
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item command="a">Apple</el-dropdown-item>
<el-dropdown-item command="b">Orange</el-dropdown-item>
<el-dropdown-item ref="c" :command="myCommandObject">Cherry</el-dropdown-item>
<el-dropdown-item command="d">Peach</el-dropdown-item>
<el-dropdown-item command="e">Pear</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
`,
() => ({
myCommandObject: { name: 'CommandC' },
name: '',
}),
)
const content = wrapper.findComponent({ ref: 'b' }).vm.$refs.popper as any
const triggerElm = wrapper.find('.el-dropdown-link')
expect(content.value).toBe(false)
await triggerElm.trigger(MOUSE_ENTER_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(content.value).toBe(false)
await triggerElm.trigger(CLICK)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(content.value).toBe(true)
})
test('split button', async () => {
const wrapper = _mount(
`
<el-dropdown @click="handleClick" split-button type="primary" ref="b" placement="right">
dropdown
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item command="a">Apple</el-dropdown-item>
<el-dropdown-item command="b">Orange</el-dropdown-item>
<el-dropdown-item ref="c" :command="myCommandObject">Cherry</el-dropdown-item>
<el-dropdown-item command="d">Peach</el-dropdown-item>
<el-dropdown-item command="e">Pear</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
`,
() => ({
myCommandObject: { name: 'CommandC' },
name: '',
}),
{
methods: {
handleClick() {
this.name = 'click'
},
},
},
)
const content = wrapper.findComponent({ ref: 'b' }).vm.$refs.popper as any
const triggerElm = wrapper.find('.el-dropdown__caret-button')
const button = wrapper.find('.el-button')
expect(content.value).toBe(false)
await button.trigger('click')
expect((wrapper.vm as any).name).toBe('click')
await triggerElm.trigger(MOUSE_ENTER_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(content.value).toBe(true)
})
test('hide on click', async () => {
const wrapper = _mount(
`
<el-dropdown ref="b" placement="right" :hide-on-click="false">
<span class="el-dropdown-link" ref="a">
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item>Apple</el-dropdown-item>
<el-dropdown-item>Orange</el-dropdown-item>
<el-dropdown-item ref="c">Cherry</el-dropdown-item>
<el-dropdown-item disabled>Peach</el-dropdown-item>
<el-dropdown-item divided>Pear</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
`,
() => ({}),
)
const content = wrapper.findComponent({ ref: 'b' }).vm.$refs.popper as any
const triggerElm = wrapper.find('.el-dropdown-link')
await triggerElm.trigger(MOUSE_ENTER_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
await wrapper.findComponent({ ref: 'c' }).trigger('click')
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(content.value).toBe(true)
})
test('triggerElm keydown', async () => {
const wrapper = _mount(
`
<el-dropdown ref="b" placement="right" :hide-on-click="false">
<span class="el-dropdown-link" ref="a">
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item>Apple</el-dropdown-item>
<el-dropdown-item>Orange</el-dropdown-item>
<el-dropdown-item ref="c">Cherry</el-dropdown-item>
<el-dropdown-item disabled>Peach</el-dropdown-item>
<el-dropdown-item divided>Pear</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
`,
() => ({}),
)
const content = wrapper.findComponent({ ref: 'b' }).vm.$refs.popper as any
const triggerElm = wrapper.find('.el-dropdown-link')
await triggerElm.trigger(MOUSE_ENTER_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
await triggerElm.trigger('keydown', {
keyCode: eventKeys.enter,
})
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(content.value).toBe(false)
await triggerElm.trigger(MOUSE_ENTER_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
await triggerElm.trigger('keydown', {
keyCode: eventKeys.tab,
})
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(content.value).toBe(false)
})
test('dropdown menu keydown', async () => {
const wrapper = _mount(
`
<el-dropdown ref="b" placement="right" :hide-on-click="false">
<span class="el-dropdown-link" ref="a">
dropdown<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<template #dropdown>
<el-dropdown-menu ref="a">
<el-dropdown-item ref="d">Apple</el-dropdown-item>
<el-dropdown-item>Orange</el-dropdown-item>
<el-dropdown-item ref="c">Cherry</el-dropdown-item>
<el-dropdown-item disabled>Peach</el-dropdown-item>
<el-dropdown-item divided>Pear</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
`,
() => ({}),
)
const content = wrapper.findComponent({ ref: 'a' })
const triggerElm = wrapper.find('.el-dropdown-link')
await triggerElm.trigger(MOUSE_ENTER_EVENT)
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
await content.trigger('keydown', {
keyCode: eventKeys.down,
})
2020-09-03 13:12:44 +08:00
await sleep(TIMEOUT)
2020-08-28 11:44:04 +08:00
expect(wrapper.findComponent({ ref: 'd' }).attributes('tabindex')).toBe('0')
})
})