mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-12-14 09:20:51 +08:00
124 lines
3.4 KiB
TypeScript
124 lines
3.4 KiB
TypeScript
|
import { mount } from '@vue/test-utils'
|
||
|
import Image from '../src/index.vue'
|
||
|
import { nextTick } from 'vue'
|
||
|
|
||
|
import { IMAGE_SUCCESS, IMAGE_FAIL } from '../../test-utils/mock'
|
||
|
|
||
|
|
||
|
describe('Image.vue', () => {
|
||
|
|
||
|
beforeAll(() => {
|
||
|
Object.defineProperty(global.Image.prototype, 'src', {
|
||
|
set(src) {
|
||
|
const type = !src || src === IMAGE_FAIL ? 'error' : 'load'
|
||
|
const event = new Event(type)
|
||
|
this.dispatchEvent(event)
|
||
|
},
|
||
|
})
|
||
|
})
|
||
|
|
||
|
test('render test', () => {
|
||
|
const wrapper = mount(Image)
|
||
|
expect(wrapper.find('.el-image').exists()).toBe(true)
|
||
|
})
|
||
|
|
||
|
test('image load success test', async () => {
|
||
|
const alt = 'this ia alt'
|
||
|
const wrapper = mount(Image, {
|
||
|
props: {
|
||
|
src: IMAGE_SUCCESS,
|
||
|
alt,
|
||
|
},
|
||
|
})
|
||
|
expect(wrapper.find('.el-image__placeholder').exists()).toBe(true)
|
||
|
await nextTick()
|
||
|
expect(wrapper.find('.el-image__inner').exists()).toBe(true)
|
||
|
expect(wrapper.find('img').exists()).toBe(true)
|
||
|
expect(wrapper.find('.el-image__placeholder').exists()).toBe(false)
|
||
|
expect(wrapper.find('.el-image__error').exists()).toBe(false)
|
||
|
})
|
||
|
|
||
|
test('image load error test', async () => {
|
||
|
const wrapper = mount(Image, {
|
||
|
props: {
|
||
|
src: IMAGE_FAIL,
|
||
|
},
|
||
|
})
|
||
|
expect(wrapper.emitted('error')).toBeDefined()
|
||
|
await nextTick()
|
||
|
expect(wrapper.find('.el-image__inner').exists()).toBe(false)
|
||
|
expect(wrapper.find('img').exists()).toBe(false)
|
||
|
expect(wrapper.find('.el-image__error').exists()).toBe(true)
|
||
|
})
|
||
|
|
||
|
test('imageStyle fit test', async () => {
|
||
|
const fits = ['fill', 'contain', 'cover', 'none', 'scale-down']
|
||
|
for (const fit of fits) {
|
||
|
const wrapper = mount(Image, {
|
||
|
props: { fit, src: IMAGE_SUCCESS },
|
||
|
})
|
||
|
await nextTick()
|
||
|
expect(wrapper.find('img').attributes('style')).toContain(`object-fit: ${fit};`)
|
||
|
}
|
||
|
})
|
||
|
|
||
|
test('preview classname test', async () => {
|
||
|
const wrapper = mount(Image, {
|
||
|
props: {
|
||
|
fit: 'cover',
|
||
|
src: IMAGE_SUCCESS,
|
||
|
previewSrcList: new Array(3).fill(IMAGE_SUCCESS),
|
||
|
},
|
||
|
})
|
||
|
await nextTick()
|
||
|
expect(wrapper.find('img').classes()).toContain('el-image__preview')
|
||
|
})
|
||
|
|
||
|
|
||
|
test('$attrs', async () => {
|
||
|
const alt = 'this ia alt'
|
||
|
const wrapper = mount(Image, {
|
||
|
props: {
|
||
|
src: IMAGE_SUCCESS,
|
||
|
alt,
|
||
|
referrerpolicy: 'origin',
|
||
|
},
|
||
|
})
|
||
|
await nextTick()
|
||
|
expect(wrapper.find('img').attributes('alt')).toBe(alt)
|
||
|
expect(wrapper.find('img').attributes('referrerpolicy')).toBe('origin')
|
||
|
})
|
||
|
|
||
|
test('pass event listeners', async() => {
|
||
|
let result = false
|
||
|
const wrapper = mount(Image, {
|
||
|
props: {
|
||
|
src: IMAGE_SUCCESS,
|
||
|
onClick: () => result = true,
|
||
|
},
|
||
|
})
|
||
|
await nextTick()
|
||
|
const inner = wrapper.find('.el-image__inner').element as HTMLElement
|
||
|
inner.click()
|
||
|
expect(result).toBeTruthy()
|
||
|
})
|
||
|
|
||
|
//@todo lazy image test
|
||
|
|
||
|
test('big image preview', async() => {
|
||
|
const wrapper = mount(Image, {
|
||
|
props: {
|
||
|
src: IMAGE_SUCCESS,
|
||
|
previewSrcList: [IMAGE_SUCCESS],
|
||
|
},
|
||
|
})
|
||
|
await nextTick()
|
||
|
expect(wrapper.find('.el-image__inner').exists()).toBe(true)
|
||
|
await wrapper.find('.el-image__inner').trigger('click')
|
||
|
const viewer = wrapper.find('.el-image-viewer__wrapper')
|
||
|
expect(viewer.exists()).toBe(true)
|
||
|
await wrapper.find('.el-image-viewer__close').trigger('click')
|
||
|
expect(wrapper.find('.el-image-viewer__wrapper').exists()).toBe(false)
|
||
|
})
|
||
|
})
|