2021-03-15 21:22:07 +08:00
|
|
|
import { h, nextTick } from 'vue'
|
2021-08-24 13:36:48 +08:00
|
|
|
import { mount } from '@vue/test-utils'
|
2022-04-27 21:38:47 +08:00
|
|
|
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest'
|
|
|
|
import { EVENT_CODE } from '@element-plus/constants'
|
2022-05-05 22:04:32 +08:00
|
|
|
import { ElFormItem } from '@element-plus/components/form'
|
2022-06-12 08:32:54 +08:00
|
|
|
import Slider from '../src/slider.vue'
|
2020-09-01 19:04:28 +08:00
|
|
|
|
2022-04-19 12:46:57 +08:00
|
|
|
vi.mock('lodash-unified', async () => {
|
2022-02-10 16:35:44 +08:00
|
|
|
return {
|
2022-04-19 12:46:57 +08:00
|
|
|
...((await vi.importActual('lodash-unified')) as Record<string, any>),
|
|
|
|
debounce: vi.fn((fn) => {
|
|
|
|
fn.cancel = vi.fn()
|
|
|
|
fn.flush = vi.fn()
|
2022-02-10 16:35:44 +08:00
|
|
|
return fn
|
|
|
|
}),
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2020-09-01 19:04:28 +08:00
|
|
|
describe('Slider', () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
beforeEach(() => {
|
|
|
|
vi.useFakeTimers()
|
|
|
|
})
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
vi.useRealTimers()
|
|
|
|
})
|
|
|
|
|
2020-09-01 19:04:28 +08:00
|
|
|
it('create', () => {
|
|
|
|
const wrapper = mount(Slider)
|
|
|
|
expect(wrapper.props().modelValue).toBe(0)
|
|
|
|
})
|
|
|
|
|
2022-04-19 12:46:57 +08:00
|
|
|
it('should not exceed min and max', async () => {
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<slider v-model="value" :min="50"></slider>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 60,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2022-04-19 12:46:57 +08:00
|
|
|
|
2022-04-27 21:38:47 +08:00
|
|
|
await nextTick()
|
2022-04-19 12:46:57 +08:00
|
|
|
wrapper.vm.value = 40
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(50)
|
|
|
|
wrapper.vm.value = 120
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(100)
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-01-07 15:44:43 +08:00
|
|
|
it('sizes', () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
|
|
|
<slider v-model="value" size="small">
|
|
|
|
</slider>
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
expect(wrapper.find('.el-slider--small').exists()).toBe(true)
|
|
|
|
})
|
|
|
|
|
2020-09-01 19:04:28 +08:00
|
|
|
it('show tooltip', () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value">
|
|
|
|
</slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2021-03-15 21:22:07 +08:00
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSliderButton' })
|
2020-09-01 19:04:28 +08:00
|
|
|
slider.vm.handleMouseEnter()
|
|
|
|
expect(slider.vm.tooltipVisible).toBeTruthy()
|
|
|
|
slider.vm.handleMouseLeave()
|
|
|
|
expect(slider.vm.tooltipVisible).toBeFalsy()
|
|
|
|
})
|
|
|
|
|
|
|
|
it('hide tooltip', () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider ref="slider" v-model="value" :show-tooltip="false">
|
|
|
|
</slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2020-11-02 11:05:08 +08:00
|
|
|
const slider = wrapper.vm.$refs.slider as any
|
|
|
|
const tooltip = slider.$refs.firstButton.$refs.tooltip
|
|
|
|
expect(tooltip.disabled).toBe(true)
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2021-03-15 21:22:07 +08:00
|
|
|
it('format tooltip', async () => {
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider ref="slider" v-model="value" :format-tooltip="formatTooltip">
|
|
|
|
</slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2022-04-27 21:38:47 +08:00
|
|
|
formatTooltip(val: number) {
|
2021-09-17 09:18:24 +08:00
|
|
|
return `$${val}`
|
2020-09-01 19:04:28 +08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
2021-03-15 21:22:07 +08:00
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSliderButton' })
|
2020-09-01 19:04:28 +08:00
|
|
|
nextTick().then(() => {
|
|
|
|
expect(slider.vm.formatValue).toBe('$0')
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2022-04-19 12:46:57 +08:00
|
|
|
describe('drag', () => {
|
|
|
|
it('horizontal', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2022-04-19 12:46:57 +08:00
|
|
|
const wrapper = mount(
|
|
|
|
{
|
|
|
|
template: `
|
|
|
|
<div style="width: 200px;">
|
|
|
|
<slider v-model="value" :vertical="false"></slider>
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
2021-09-04 19:29:28 +08:00
|
|
|
},
|
2022-04-19 12:46:57 +08:00
|
|
|
{
|
|
|
|
attachTo: document.body,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
const slider = wrapper.findComponent({ name: 'ElSliderButton' })
|
|
|
|
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.spyOn(
|
|
|
|
wrapper.find('.el-slider__runway').element,
|
|
|
|
'clientWidth',
|
|
|
|
'get'
|
|
|
|
).mockImplementation(() => 200)
|
2022-04-19 12:46:57 +08:00
|
|
|
slider.trigger('mousedown', { clientX: 0 })
|
|
|
|
|
|
|
|
const mousemove = document.createEvent('MouseEvent')
|
|
|
|
mousemove.initMouseEvent(
|
|
|
|
'mousemove',
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
window,
|
|
|
|
1,
|
|
|
|
100,
|
|
|
|
0,
|
|
|
|
100,
|
|
|
|
0,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
null
|
|
|
|
)
|
|
|
|
window.dispatchEvent(mousemove)
|
|
|
|
|
|
|
|
const mouseup = document.createEvent('MouseEvent')
|
|
|
|
mouseup.initMouseEvent(
|
|
|
|
'mouseup',
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
window,
|
|
|
|
1,
|
|
|
|
100,
|
|
|
|
0,
|
|
|
|
100,
|
|
|
|
0,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
null
|
|
|
|
)
|
|
|
|
window.dispatchEvent(mouseup)
|
|
|
|
|
|
|
|
await nextTick()
|
2020-09-01 19:04:28 +08:00
|
|
|
expect(wrapper.vm.value === 50).toBeTruthy()
|
2022-04-19 12:46:57 +08:00
|
|
|
})
|
2020-09-01 19:04:28 +08:00
|
|
|
|
2022-04-19 12:46:57 +08:00
|
|
|
it('vertical', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2022-04-19 12:46:57 +08:00
|
|
|
const wrapper = mount(
|
|
|
|
{
|
|
|
|
template: `
|
|
|
|
<div style="height: 200px;">
|
|
|
|
<slider v-model="value" :vertical="true"></slider>
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
attachTo: document.body,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
const slider = wrapper.findComponent({ name: 'ElSliderButton' })
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.spyOn(
|
|
|
|
wrapper.find('.el-slider__runway').element,
|
|
|
|
'clientHeight',
|
|
|
|
'get'
|
|
|
|
).mockImplementation(() => 200)
|
2022-04-19 12:46:57 +08:00
|
|
|
slider.trigger('mousedown', { clientY: 0 })
|
|
|
|
const mousemove = document.createEvent('MouseEvent')
|
|
|
|
mousemove.initMouseEvent(
|
|
|
|
'mousemove',
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
window,
|
|
|
|
1,
|
|
|
|
0,
|
|
|
|
-100,
|
|
|
|
0,
|
|
|
|
-100,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
null
|
|
|
|
)
|
|
|
|
window.dispatchEvent(mousemove)
|
|
|
|
const mouseup = document.createEvent('MouseEvent')
|
|
|
|
mouseup.initMouseEvent(
|
|
|
|
'mouseup',
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
window,
|
|
|
|
1,
|
|
|
|
0,
|
|
|
|
-100,
|
|
|
|
0,
|
|
|
|
-100,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
null
|
|
|
|
)
|
|
|
|
window.dispatchEvent(mouseup)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(50)
|
|
|
|
})
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-04-27 21:38:47 +08:00
|
|
|
describe('accessibility', () => {
|
|
|
|
it('left/right arrows', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
|
|
|
<slider v-model="value"></slider>
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0.1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSliderButton' })
|
|
|
|
|
|
|
|
slider.vm.onKeyDown(
|
|
|
|
new KeyboardEvent('keydown', { key: EVENT_CODE.right })
|
|
|
|
)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(1)
|
|
|
|
|
|
|
|
slider.vm.onKeyDown(
|
|
|
|
new KeyboardEvent('keydown', { key: EVENT_CODE.left })
|
|
|
|
)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(0)
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
2022-04-27 21:38:47 +08:00
|
|
|
|
|
|
|
it('up/down arrows', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
|
|
|
<slider v-model="value"></slider>
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0.1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSliderButton' })
|
|
|
|
|
|
|
|
slider.vm.onKeyDown(new KeyboardEvent('keydown', { key: EVENT_CODE.up }))
|
|
|
|
await nextTick()
|
2020-09-01 19:04:28 +08:00
|
|
|
expect(wrapper.vm.value).toBe(1)
|
2022-04-27 21:38:47 +08:00
|
|
|
|
|
|
|
slider.vm.onKeyDown(
|
|
|
|
new KeyboardEvent('keydown', { key: EVENT_CODE.down })
|
|
|
|
)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(0)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('page up/down keys', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
|
|
|
<slider v-model="value" :min="-5" :max="10"></slider>
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: -1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSliderButton' })
|
|
|
|
slider.vm.onKeyDown(
|
|
|
|
new KeyboardEvent('keydown', { key: EVENT_CODE.pageUp })
|
|
|
|
)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(3)
|
|
|
|
|
|
|
|
slider.vm.onKeyDown(
|
|
|
|
new KeyboardEvent('keydown', { key: EVENT_CODE.pageDown })
|
|
|
|
)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(-1)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('home/end keys', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
|
|
|
<slider v-model="value" :min="-5" :max="10"></slider>
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSliderButton' })
|
|
|
|
slider.vm.onKeyDown(
|
|
|
|
new KeyboardEvent('keydown', { key: EVENT_CODE.home })
|
|
|
|
)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(-5)
|
|
|
|
|
|
|
|
slider.vm.onKeyDown(new KeyboardEvent('keydown', { key: EVENT_CODE.end }))
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(10)
|
|
|
|
})
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-05-17 20:32:52 +08:00
|
|
|
it('step', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2021-09-04 19:29:28 +08:00
|
|
|
const wrapper = mount(
|
|
|
|
{
|
|
|
|
template: `
|
2020-09-01 19:04:28 +08:00
|
|
|
<div style="width: 200px;">
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value" :min="0" :max="1" :step="0.1"></slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
2021-09-04 19:29:28 +08:00
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
2020-09-01 19:04:28 +08:00
|
|
|
},
|
2021-09-04 19:29:28 +08:00
|
|
|
{
|
|
|
|
attachTo: document.body,
|
|
|
|
}
|
|
|
|
)
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockClientWidth = vi
|
2021-03-15 21:22:07 +08:00
|
|
|
.spyOn(wrapper.find('.el-slider__runway').element, 'clientWidth', 'get')
|
2020-09-02 18:49:08 +08:00
|
|
|
.mockImplementation(() => 200)
|
2021-03-15 21:22:07 +08:00
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSliderButton' })
|
2022-05-17 20:32:52 +08:00
|
|
|
await nextTick()
|
|
|
|
|
|
|
|
slider.trigger('mousedown', { clientX: 0 })
|
|
|
|
const mousemove = document.createEvent('MouseEvent')
|
|
|
|
mousemove.initMouseEvent(
|
|
|
|
'mousemove',
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
window,
|
|
|
|
1,
|
|
|
|
100,
|
|
|
|
0,
|
|
|
|
100,
|
|
|
|
0,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
null
|
|
|
|
)
|
|
|
|
window.dispatchEvent(mousemove)
|
|
|
|
const mouseup = document.createEvent('MouseEvent')
|
|
|
|
mouseup.initMouseEvent(
|
|
|
|
'mouseup',
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
window,
|
|
|
|
1,
|
|
|
|
100,
|
|
|
|
0,
|
|
|
|
100,
|
|
|
|
0,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
null
|
|
|
|
)
|
|
|
|
await nextTick()
|
|
|
|
window.dispatchEvent(mouseup)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value === 0.5).toBeTruthy()
|
|
|
|
mockClientWidth.mockRestore()
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-05-17 20:32:52 +08:00
|
|
|
it('click', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value"></slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2022-04-27 21:38:47 +08:00
|
|
|
const mockClientWidth = vi
|
|
|
|
.spyOn(wrapper.find('.el-slider__runway').element, 'clientWidth', 'get')
|
|
|
|
.mockImplementation(() => 200)
|
2021-03-15 21:22:07 +08:00
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSlider' })
|
2022-05-17 20:32:52 +08:00
|
|
|
slider.vm.onSliderClick(new MouseEvent('mousedown', { clientX: 100 }))
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value > 0).toBeTruthy()
|
|
|
|
mockClientWidth.mockRestore()
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-05-17 20:32:52 +08:00
|
|
|
it('change event', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div style="width: 200px">
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value" @change="onChange">
|
|
|
|
</slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
data: 0,
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2022-04-27 21:38:47 +08:00
|
|
|
onChange(val: number) {
|
2020-09-01 19:04:28 +08:00
|
|
|
this.data = val
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
2021-03-15 21:22:07 +08:00
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSlider' })
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockRectLeft = vi
|
2021-09-04 19:29:28 +08:00
|
|
|
.spyOn(
|
|
|
|
wrapper.find('.el-slider__runway').element,
|
|
|
|
'getBoundingClientRect'
|
|
|
|
)
|
2020-09-02 18:49:08 +08:00
|
|
|
.mockImplementation(() => {
|
2020-09-01 19:04:28 +08:00
|
|
|
return {
|
|
|
|
left: 0,
|
2020-09-02 18:49:08 +08:00
|
|
|
} as DOMRect
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockClientWidth = vi
|
2021-03-15 21:22:07 +08:00
|
|
|
.spyOn(wrapper.find('.el-slider__runway').element, 'clientWidth', 'get')
|
2020-09-02 18:49:08 +08:00
|
|
|
.mockImplementation(() => 200)
|
2022-05-17 20:32:52 +08:00
|
|
|
expect(wrapper.vm.data).toBe(0)
|
|
|
|
slider.vm.onSliderClick(new MouseEvent('mousedown', { clientX: 100 }))
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.data === 50).toBeTruthy()
|
|
|
|
mockRectLeft.mockRestore()
|
|
|
|
mockClientWidth.mockRestore()
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-05-17 20:32:52 +08:00
|
|
|
it('input event', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2021-04-09 10:40:50 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div style="width: 200px">
|
|
|
|
<slider v-model="value" @input="onInput">
|
|
|
|
</slider>
|
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
data: 0,
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2022-04-27 21:38:47 +08:00
|
|
|
onInput(val: number) {
|
2021-04-09 10:40:50 +08:00
|
|
|
this.data = val
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSlider' })
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockRectLeft = vi
|
2021-09-04 19:29:28 +08:00
|
|
|
.spyOn(
|
|
|
|
wrapper.find('.el-slider__runway').element,
|
|
|
|
'getBoundingClientRect'
|
|
|
|
)
|
2021-04-09 10:40:50 +08:00
|
|
|
.mockImplementation(() => {
|
|
|
|
return {
|
|
|
|
left: 0,
|
|
|
|
} as DOMRect
|
|
|
|
})
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockClientWidth = vi
|
2021-04-09 10:40:50 +08:00
|
|
|
.spyOn(wrapper.find('.el-slider__runway').element, 'clientWidth', 'get')
|
|
|
|
.mockImplementation(() => 200)
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.data).toBe(0)
|
2022-04-27 21:38:47 +08:00
|
|
|
slider.vm.onSliderClick(new MouseEvent('mousedown', { clientX: 100 }))
|
2021-04-09 10:40:50 +08:00
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.data === 50).toBeTruthy()
|
|
|
|
mockRectLeft.mockRestore()
|
|
|
|
mockClientWidth.mockRestore()
|
|
|
|
})
|
|
|
|
|
2022-05-17 20:32:52 +08:00
|
|
|
it('disabled', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value" disabled></slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockClientWidth = vi
|
2020-09-02 18:49:08 +08:00
|
|
|
.spyOn(wrapper.find('.el-slider__runway').element, 'clientWidth', 'get')
|
|
|
|
.mockImplementation(() => 200)
|
2021-03-15 21:22:07 +08:00
|
|
|
const slider: any = wrapper.findComponent({ name: 'ElSliderButton' })
|
2020-09-01 19:04:28 +08:00
|
|
|
slider.vm.onButtonDown({ clientX: 0 })
|
|
|
|
const mousemove = document.createEvent('MouseEvent')
|
2021-09-04 19:29:28 +08:00
|
|
|
mousemove.initMouseEvent(
|
|
|
|
'mousemove',
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
window,
|
|
|
|
1,
|
|
|
|
50,
|
|
|
|
0,
|
|
|
|
50,
|
|
|
|
0,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
null
|
|
|
|
)
|
2020-09-01 19:04:28 +08:00
|
|
|
window.dispatchEvent(mousemove)
|
|
|
|
const mouseup = document.createEvent('MouseEvent')
|
2021-09-04 19:29:28 +08:00
|
|
|
mouseup.initMouseEvent(
|
|
|
|
'mouseup',
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
window,
|
|
|
|
1,
|
|
|
|
50,
|
|
|
|
0,
|
|
|
|
50,
|
|
|
|
0,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
null
|
|
|
|
)
|
2020-09-01 19:04:28 +08:00
|
|
|
window.dispatchEvent(mouseup)
|
2022-05-17 20:32:52 +08:00
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toBe(0)
|
|
|
|
mockClientWidth.mockRestore()
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-05-17 20:32:52 +08:00
|
|
|
it('show input', async () => {
|
2020-10-26 10:56:14 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value" show-input></slider>
|
2020-10-26 10:56:14 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
const increaseButton = wrapper.find('.el-input-number__increase')
|
2022-05-17 20:32:52 +08:00
|
|
|
await increaseButton.trigger('mousedown')
|
|
|
|
vi.advanceTimersByTime(200)
|
|
|
|
expect(wrapper.vm.value > 0).toBeTruthy()
|
2020-10-26 10:56:14 +08:00
|
|
|
})
|
2020-09-01 19:04:28 +08:00
|
|
|
|
|
|
|
it('show stops', () => {
|
|
|
|
const wrapper = mount(Slider, {
|
|
|
|
props: {
|
|
|
|
showStops: true,
|
|
|
|
step: 10,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
const stops = wrapper.findAll('.el-slider__stop')
|
|
|
|
expect(stops.length).toBe(9)
|
|
|
|
})
|
|
|
|
|
2022-05-17 20:32:52 +08:00
|
|
|
it('vertical mode', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2021-09-04 19:29:28 +08:00
|
|
|
const wrapper = mount(
|
|
|
|
{
|
|
|
|
template: `
|
2020-09-01 19:04:28 +08:00
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider vertical v-model="value" height="200px"></slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
2021-09-04 19:29:28 +08:00
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: 0,
|
|
|
|
}
|
|
|
|
},
|
2020-09-01 19:04:28 +08:00
|
|
|
},
|
2021-09-04 19:29:28 +08:00
|
|
|
{
|
|
|
|
attachTo: document.body,
|
|
|
|
}
|
|
|
|
)
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockRectBottom = vi
|
2021-09-04 19:29:28 +08:00
|
|
|
.spyOn(
|
|
|
|
wrapper.find('.el-slider__runway').element,
|
|
|
|
'getBoundingClientRect'
|
|
|
|
)
|
2020-09-02 18:49:08 +08:00
|
|
|
.mockImplementation(() => {
|
2020-09-01 19:04:28 +08:00
|
|
|
return {
|
|
|
|
bottom: 200,
|
2020-09-02 18:49:08 +08:00
|
|
|
} as DOMRect
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockClientHeight = vi
|
2020-09-02 18:49:08 +08:00
|
|
|
.spyOn(wrapper.find('.el-slider__runway').element, 'clientHeight', 'get')
|
|
|
|
.mockImplementation(() => 200)
|
2021-03-15 21:22:07 +08:00
|
|
|
const slider: any = wrapper.getComponent({ name: 'ElSlider' })
|
2022-05-17 20:32:52 +08:00
|
|
|
slider.vm.onSliderClick(new MouseEvent('mousedown', { clientX: 100 }))
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value > 0).toBeTruthy()
|
|
|
|
mockRectBottom.mockRestore()
|
|
|
|
mockClientHeight.mockRestore()
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2021-03-15 21:22:07 +08:00
|
|
|
it('rerender with min and show-input', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: '<slider v-if="show" v-model="value" :min="10" show-input/>',
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
show: false,
|
|
|
|
value: 30,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
mounted() {
|
|
|
|
this.show = true
|
|
|
|
},
|
|
|
|
})
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toEqual(30)
|
|
|
|
})
|
|
|
|
|
2020-09-01 19:04:28 +08:00
|
|
|
describe('range', () => {
|
|
|
|
it('basic ranged slider', () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
2021-03-15 21:22:07 +08:00
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value" range></slider>
|
2021-03-15 21:22:07 +08:00
|
|
|
</div>
|
|
|
|
`,
|
2020-09-01 19:04:28 +08:00
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: [10, 20],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2021-03-15 21:22:07 +08:00
|
|
|
const sliders = wrapper.findAllComponents({ name: 'ElSliderButton' })
|
2020-09-01 19:04:28 +08:00
|
|
|
expect(sliders.length).toBe(2)
|
|
|
|
})
|
|
|
|
|
2022-04-27 21:38:47 +08:00
|
|
|
it('should not exceed min and max', async () => {
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value" range :min="50">
|
|
|
|
</slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: [50, 60],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2022-04-27 21:38:47 +08:00
|
|
|
await nextTick()
|
|
|
|
|
|
|
|
wrapper.vm.value = [40, 60]
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toStrictEqual([50, 60])
|
|
|
|
|
|
|
|
wrapper.vm.value = [50, 120]
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toStrictEqual([50, 100])
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-05-17 20:32:52 +08:00
|
|
|
it('click', async () => {
|
2022-04-27 21:38:47 +08:00
|
|
|
vi.useRealTimers()
|
2021-09-04 19:29:28 +08:00
|
|
|
const wrapper = mount(
|
|
|
|
{
|
|
|
|
template: `
|
2020-09-01 19:04:28 +08:00
|
|
|
<div style="width: 200px;">
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider range v-model="value"></slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
2021-09-04 19:29:28 +08:00
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: [0, 100],
|
|
|
|
}
|
|
|
|
},
|
2020-09-01 19:04:28 +08:00
|
|
|
},
|
2021-09-04 19:29:28 +08:00
|
|
|
{
|
|
|
|
attachTo: document.body,
|
|
|
|
}
|
|
|
|
)
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockRectLeft = vi
|
2021-09-04 19:29:28 +08:00
|
|
|
.spyOn(
|
|
|
|
wrapper.find('.el-slider__runway').element,
|
|
|
|
'getBoundingClientRect'
|
|
|
|
)
|
2020-09-02 18:49:08 +08:00
|
|
|
.mockImplementation(() => {
|
2020-09-01 19:04:28 +08:00
|
|
|
return {
|
|
|
|
left: 0,
|
2020-09-02 18:49:08 +08:00
|
|
|
} as DOMRect
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
2022-04-19 12:46:57 +08:00
|
|
|
const mockClientWidth = vi
|
2021-03-15 21:22:07 +08:00
|
|
|
.spyOn(wrapper.find('.el-slider__runway').element, 'clientWidth', 'get')
|
2020-09-02 18:49:08 +08:00
|
|
|
.mockImplementation(() => 200)
|
2021-03-15 21:22:07 +08:00
|
|
|
const slider: any = wrapper.getComponent({ name: 'ElSlider' })
|
2022-05-17 20:32:52 +08:00
|
|
|
slider.vm.onSliderClick(new MouseEvent('mousedown', { clientX: 100 }))
|
|
|
|
await nextTick()
|
|
|
|
// Because mock the clientWidth, so the targetValue is 50.
|
|
|
|
// The behavior of the setPosition method in the useSlider.ts file should be that the value of the second button is 50
|
|
|
|
expect(wrapper.vm.value[0] === 0).toBeTruthy()
|
|
|
|
expect(wrapper.vm.value[1] === 50).toBeTruthy()
|
|
|
|
mockRectLeft.mockRestore()
|
|
|
|
mockClientWidth.mockRestore()
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-04-27 21:38:47 +08:00
|
|
|
it('responsive to dynamic min and max', async () => {
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider v-model="value" range :min="min" :max="max">
|
|
|
|
</slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
min: 0,
|
|
|
|
max: 100,
|
|
|
|
value: [50, 80],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2022-04-27 21:38:47 +08:00
|
|
|
await nextTick()
|
|
|
|
|
|
|
|
wrapper.vm.min = 60
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toStrictEqual([60, 80])
|
|
|
|
|
|
|
|
wrapper.vm.min = 30
|
|
|
|
wrapper.vm.max = 40
|
|
|
|
await nextTick()
|
|
|
|
expect(wrapper.vm.value).toStrictEqual([40, 40])
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2022-04-27 21:38:47 +08:00
|
|
|
it('show stops', async () => {
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider
|
|
|
|
v-model="value"
|
|
|
|
range
|
|
|
|
:step="10"
|
|
|
|
show-stops
|
|
|
|
></slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: [30, 60],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
2022-04-27 21:38:47 +08:00
|
|
|
await nextTick()
|
|
|
|
const stops = wrapper.findAll('.el-slider__stop')
|
|
|
|
expect(stops.length).toBe(5)
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
|
2021-03-15 21:22:07 +08:00
|
|
|
it('marks', async () => {
|
2020-09-01 19:04:28 +08:00
|
|
|
const wrapper = mount({
|
|
|
|
template: `
|
|
|
|
<div>
|
2021-04-09 10:40:50 +08:00
|
|
|
<slider
|
|
|
|
v-model="value"
|
|
|
|
range
|
|
|
|
:step="10"
|
|
|
|
:marks="marks"
|
|
|
|
:min="20"
|
|
|
|
show-stops
|
|
|
|
></slider>
|
2020-09-01 19:04:28 +08:00
|
|
|
</div>
|
|
|
|
`,
|
|
|
|
components: { Slider },
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
value: [30, 60],
|
|
|
|
marks: {
|
|
|
|
0: '0°C',
|
|
|
|
8: '8°C',
|
|
|
|
37: '37°C',
|
|
|
|
50: {
|
|
|
|
style: {
|
|
|
|
color: '#f50',
|
|
|
|
},
|
|
|
|
label: h('strong', '50°C'),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2022-04-27 21:38:47 +08:00
|
|
|
await nextTick()
|
|
|
|
const stops = wrapper.findAll('.el-slider__marks-stop.el-slider__stop')
|
|
|
|
const marks = wrapper.findAll('.el-slider__marks .el-slider__marks-text')
|
|
|
|
expect(marks.length).toBe(2)
|
|
|
|
expect(stops.length).toBe(2)
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|
|
|
|
})
|
2022-05-05 22:04:32 +08:00
|
|
|
|
|
|
|
describe('form item accessibility integration', () => {
|
|
|
|
it('automatic id attachment', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `<el-form-item label="Foobar" data-test-ref="item">
|
|
|
|
<el-slider />
|
|
|
|
</el-form-item>`,
|
|
|
|
components: {
|
|
|
|
'el-slider': Slider,
|
|
|
|
'el-form-item': ElFormItem,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
await nextTick()
|
|
|
|
const formItem = wrapper.find('[data-test-ref="item"]')
|
|
|
|
const formItemLabel = formItem.find('.el-form-item__label')
|
|
|
|
const sliderButton = wrapper.find('.el-slider__button-wrapper')
|
|
|
|
expect(formItem.attributes().role).toBeFalsy()
|
|
|
|
expect(formItemLabel.attributes().for).toBe(sliderButton.attributes().id)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('range with automatic id attachment', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `<el-form-item label="Foobar" data-test-ref="item">
|
|
|
|
<el-slider :range="true" />
|
|
|
|
</el-form-item>`,
|
|
|
|
components: {
|
|
|
|
'el-slider': Slider,
|
|
|
|
'el-form-item': ElFormItem,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
await nextTick()
|
|
|
|
const formItem = wrapper.find('[data-test-ref="item"]')
|
|
|
|
const formItemLabel = formItem.find('.el-form-item__label')
|
|
|
|
const sliderWrapper = wrapper.find('.el-slider')
|
|
|
|
expect(formItem.attributes().role).toBeFalsy()
|
|
|
|
expect(formItemLabel.attributes().for).toBe(sliderWrapper.attributes().id)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('specified id attachment', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `<el-form-item label="Foobar" data-test-ref="item">
|
|
|
|
<el-slider id="foobar" />
|
|
|
|
</el-form-item>`,
|
|
|
|
components: {
|
|
|
|
'el-slider': Slider,
|
|
|
|
'el-form-item': ElFormItem,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
await nextTick()
|
|
|
|
const formItem = wrapper.find('[data-test-ref="item"]')
|
|
|
|
const formItemLabel = formItem.find('.el-form-item__label')
|
|
|
|
const sliderButton = wrapper.find('.el-slider__button-wrapper')
|
|
|
|
expect(formItem.attributes().role).toBeFalsy()
|
|
|
|
expect(sliderButton.attributes().id).toBe('foobar')
|
|
|
|
expect(formItemLabel.attributes().for).toBe(sliderButton.attributes().id)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('range with specified id attachment', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `<el-form-item label="Foobar" data-test-ref="item">
|
|
|
|
<el-slider id="foobar" :range="true" />
|
|
|
|
</el-form-item>`,
|
|
|
|
components: {
|
|
|
|
'el-slider': Slider,
|
|
|
|
'el-form-item': ElFormItem,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
await nextTick()
|
|
|
|
const formItem = wrapper.find('[data-test-ref="item"]')
|
|
|
|
const formItemLabel = formItem.find('.el-form-item__label')
|
|
|
|
const sliderWrapper = wrapper.find('.el-slider')
|
|
|
|
expect(formItem.attributes().role).toBeFalsy()
|
|
|
|
expect(sliderWrapper.attributes().id).toBe('foobar')
|
|
|
|
expect(formItemLabel.attributes().for).toBe(sliderWrapper.attributes().id)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('form item role is group when multiple inputs', async () => {
|
|
|
|
const wrapper = mount({
|
|
|
|
template: `<el-form-item label="Foobar" data-test-ref="item">
|
|
|
|
<el-slider />
|
|
|
|
<el-slider />
|
|
|
|
</el-form-item>`,
|
|
|
|
components: {
|
|
|
|
'el-slider': Slider,
|
|
|
|
'el-form-item': ElFormItem,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
await nextTick()
|
|
|
|
const formItem = wrapper.find('[data-test-ref="item"]')
|
|
|
|
expect(formItem.attributes().role).toBe('group')
|
|
|
|
})
|
|
|
|
})
|
2020-09-01 19:04:28 +08:00
|
|
|
})
|