mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-12-14 01:11:25 +08:00
1f8fc62d73
* feat: init carousel component * feat(carousel): init carousel component * chore: add global dependencies * chore: use prettier formate code * feat(carousel): transfer logic - progress 40% * feat(carousel): migrate logic - progress 50% * feat(carousel): migrate logic - progress 55% * feat(carousel): replenish doc * feat(carousel): add utils * feat(carousel): finish component logi * feat(carousel): fix type error * feat(carousel): test case 80% * feat(carousel): migrate finish * feat(carousel): more test cases * feat(carousel): test case passed * feat(carousel): fix CI dependencies collides * feat(carousel): update yarn.lock * feat(carousel): merge sub component * feat(carousel): fix lose ctx attribute in buid env * feat(carousel): finish spec * feat(carousel): optimize code * chore: update yarn lock * feat(carousel): fall back lock file * chore(carousel): fallback dep * feat(carousel): update vue dep * feat(carousel): update spec file * feat(carousel): use async test * feat(carousel): revert eslint modify Co-authored-by: liik <385211478@qq.com> Co-authored-by: liik <linyunqianpp@126.com>
201 lines
5.5 KiB
TypeScript
201 lines
5.5 KiB
TypeScript
import { mount } from '@vue/test-utils'
|
|
import { nextTick } from 'vue'
|
|
import Carousel from '../src/main.vue'
|
|
import CarouselItem from '../src/item.vue'
|
|
|
|
const wait = (ms = 100) =>
|
|
new Promise(resolve => setTimeout(() => resolve(), ms))
|
|
|
|
const _mount = (template: string, data?: () => void, methods?: any) =>
|
|
mount({
|
|
components: {
|
|
'el-carousel': Carousel,
|
|
'el-carousel-item': CarouselItem,
|
|
},
|
|
template,
|
|
data,
|
|
methods,
|
|
})
|
|
|
|
describe('Carousel', () => {
|
|
it('create', () => {
|
|
const wrapper = _mount(
|
|
`
|
|
<div>
|
|
<el-carousel ref="carousel">
|
|
<el-carousel-item v-for="item in 3" :key="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`,
|
|
)
|
|
|
|
expect(wrapper.vm.$refs.carousel.direction).toBe('horizontal')
|
|
expect(wrapper.findAll('.el-carousel__item').length).toEqual(3)
|
|
})
|
|
|
|
it('auto play', async done => {
|
|
const wrapper = _mount(`
|
|
<div>
|
|
<el-carousel :interval="50">
|
|
<el-carousel-item v-for="item in 3" :key="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`)
|
|
|
|
await nextTick()
|
|
await wait(10)
|
|
const items = wrapper.vm.$el.querySelectorAll('.el-carousel__item')
|
|
expect(items[0].classList.contains('is-active')).toBeTruthy()
|
|
await wait(60)
|
|
expect(items[1].classList.contains('is-active')).toBeTruthy()
|
|
done()
|
|
})
|
|
|
|
it('initial index', async done => {
|
|
const wrapper = _mount(`
|
|
<div>
|
|
<el-carousel :autoplay="false" :initial-index="1">
|
|
<el-carousel-item v-for="item in 3" :key="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`)
|
|
|
|
await nextTick()
|
|
await wait(10)
|
|
|
|
expect(
|
|
wrapper.vm.$el
|
|
.querySelectorAll('.el-carousel__item')[1]
|
|
.classList.contains('is-active'),
|
|
).toBeTruthy()
|
|
done()
|
|
})
|
|
|
|
it('reset timer', async done => {
|
|
const wrapper = _mount(`
|
|
<div>
|
|
<el-carousel :interval="500">
|
|
<el-carousel-item v-for="item in 3" :key="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`)
|
|
await nextTick()
|
|
const items = wrapper.vm.$el.querySelectorAll('.el-carousel__item')
|
|
await wrapper.trigger('mouseenter')
|
|
await nextTick()
|
|
expect(items[0].classList.contains('is-active')).toBeTruthy()
|
|
await wrapper.trigger('mouseleave')
|
|
await nextTick()
|
|
await wait(700)
|
|
expect(items[1].classList.contains('is-active')).toBeTruthy()
|
|
done()
|
|
})
|
|
|
|
it('change', async done => {
|
|
const wrapper = _mount(
|
|
`
|
|
<div>
|
|
<el-carousel :interval="50" @change="handleChange">
|
|
<el-carousel-item v-for="item in 3" :key="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`,
|
|
() => {
|
|
return {
|
|
val: -1,
|
|
oldVal: -1,
|
|
}
|
|
},
|
|
{
|
|
handleChange(val, oldVal) {
|
|
this.val = val
|
|
this.oldVal = oldVal
|
|
},
|
|
},
|
|
)
|
|
|
|
await nextTick()
|
|
await wait(50)
|
|
expect(wrapper.vm.val).toBe(1)
|
|
expect(wrapper.vm.oldVal).toBe(0)
|
|
done()
|
|
})
|
|
|
|
it('label', async done => {
|
|
const wrapper = _mount(`
|
|
<div>
|
|
<el-carousel>
|
|
<el-carousel-item v-for="item in 3" :key="item" :label="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`)
|
|
await nextTick()
|
|
expect(wrapper.find('.el-carousel__button span').text()).toBe('1')
|
|
done()
|
|
})
|
|
|
|
describe('manual control', () => {
|
|
it('hover', async done => {
|
|
const wrapper = _mount(`
|
|
<div>
|
|
<el-carousel :autoplay="false">
|
|
<el-carousel-item v-for="item in 3" :key="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`)
|
|
|
|
await nextTick()
|
|
await wait()
|
|
await wrapper.findAll('.el-carousel__indicator')[1].trigger('mouseenter')
|
|
await nextTick()
|
|
await wait()
|
|
expect(
|
|
wrapper.vm.$el
|
|
.querySelectorAll('.el-carousel__item')[1]
|
|
.classList.contains('is-active'),
|
|
).toBeTruthy()
|
|
done()
|
|
})
|
|
})
|
|
|
|
it('card', async done => {
|
|
const wrapper = _mount(`
|
|
<div>
|
|
<el-carousel :autoplay="false" type="card">
|
|
<el-carousel-item v-for="item in 7" :key="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`)
|
|
await nextTick()
|
|
await wait()
|
|
const items = wrapper.vm.$el.querySelectorAll('.el-carousel__item')
|
|
expect(items[0].classList.contains('is-active')).toBeTruthy()
|
|
expect(items[1].classList.contains('is-in-stage')).toBeTruthy()
|
|
expect(items[6].classList.contains('is-in-stage')).toBeTruthy()
|
|
await items[1].click()
|
|
await wait()
|
|
expect(items[1].classList.contains('is-active')).toBeTruthy()
|
|
await wrapper.vm.$el.querySelector('.el-carousel__arrow--left').click()
|
|
await wait()
|
|
expect(items[0].classList.contains('is-active')).toBeTruthy()
|
|
await items[6].click()
|
|
await wait()
|
|
expect(items[6].classList.contains('is-active')).toBeTruthy()
|
|
done()
|
|
})
|
|
|
|
it('vertical direction', () => {
|
|
const wrapper = _mount(`
|
|
<div>
|
|
<el-carousel ref="carousel" :autoplay="false" direction="vertical" height="100px">
|
|
<el-carousel-item v-for="item in 3" :key="item"></el-carousel-item>
|
|
</el-carousel>
|
|
</div>
|
|
`)
|
|
const items = wrapper.vm.$el.querySelectorAll('.el-carousel__item')
|
|
|
|
expect(wrapper.vm.$refs.carousel.direction).toBe('vertical')
|
|
expect(items[0].style.transform.indexOf('translateY') !== -1).toBeTruthy()
|
|
})
|
|
})
|