2020-08-27 21:22:32 +08:00
|
|
|
import { nextTick } from 'vue'
|
2021-09-17 15:27:31 +08:00
|
|
|
import { mount } from '@vue/test-utils'
|
2021-09-04 19:29:28 +08:00
|
|
|
import {
|
|
|
|
IMAGE_SUCCESS,
|
|
|
|
IMAGE_FAIL,
|
|
|
|
mockImageEvent,
|
|
|
|
} from '@element-plus/test-utils/mock'
|
2021-10-06 20:17:18 +08:00
|
|
|
import Image from '../src/image.vue'
|
2020-08-27 21:22:32 +08:00
|
|
|
|
2020-09-05 12:17:37 +08:00
|
|
|
// firstly wait for image event
|
|
|
|
// secondly wait for vue render
|
|
|
|
async function doubleWait() {
|
|
|
|
await nextTick()
|
|
|
|
await nextTick()
|
|
|
|
}
|
2020-08-27 21:22:32 +08:00
|
|
|
|
|
|
|
describe('Image.vue', () => {
|
2020-09-07 17:41:18 +08:00
|
|
|
mockImageEvent()
|
2020-08-27 21:22:32 +08:00
|
|
|
|
|
|
|
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)
|
2020-09-05 12:17:37 +08:00
|
|
|
await doubleWait()
|
2020-08-27 21:22:32 +08:00
|
|
|
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,
|
|
|
|
},
|
|
|
|
})
|
2020-09-05 12:17:37 +08:00
|
|
|
await doubleWait()
|
2020-08-27 21:22:32 +08:00
|
|
|
expect(wrapper.emitted('error')).toBeDefined()
|
|
|
|
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)
|
|
|
|
})
|
|
|
|
|
2022-01-18 22:26:28 +08:00
|
|
|
test('image load sequence success test', async () => {
|
|
|
|
const wrapper = mount(Image, {
|
|
|
|
props: {
|
|
|
|
src: IMAGE_FAIL,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
wrapper.setProps({
|
|
|
|
src: IMAGE_SUCCESS,
|
|
|
|
})
|
|
|
|
expect(wrapper.find('.el-image__placeholder').exists()).toBe(true)
|
|
|
|
await doubleWait()
|
|
|
|
expect(wrapper.emitted('error')).toBeUndefined()
|
|
|
|
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)
|
|
|
|
})
|
|
|
|
|
2020-08-27 21:22:32 +08:00
|
|
|
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 },
|
|
|
|
})
|
2020-09-05 12:17:37 +08:00
|
|
|
await doubleWait()
|
2021-09-04 19:29:28 +08:00
|
|
|
expect(wrapper.find('img').attributes('style')).toContain(
|
|
|
|
`object-fit: ${fit};`
|
|
|
|
)
|
2020-08-27 21:22:32 +08:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
test('preview classname test', async () => {
|
|
|
|
const wrapper = mount(Image, {
|
|
|
|
props: {
|
|
|
|
fit: 'cover',
|
|
|
|
src: IMAGE_SUCCESS,
|
|
|
|
previewSrcList: new Array(3).fill(IMAGE_SUCCESS),
|
|
|
|
},
|
|
|
|
})
|
2020-09-05 12:17:37 +08:00
|
|
|
await doubleWait()
|
2020-08-27 21:22:32 +08:00
|
|
|
expect(wrapper.find('img').classes()).toContain('el-image__preview')
|
|
|
|
})
|
|
|
|
|
2021-11-05 17:52:13 +08:00
|
|
|
test('preview initial index test', async () => {
|
|
|
|
const wrapper = mount(Image, {
|
|
|
|
props: {
|
|
|
|
src: IMAGE_SUCCESS,
|
|
|
|
previewSrcList: new Array(3).fill(IMAGE_FAIL),
|
|
|
|
initialIndex: 1,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
await doubleWait()
|
|
|
|
await wrapper.find('.el-image__inner').trigger('click')
|
|
|
|
expect(
|
|
|
|
wrapper.findAll('.el-image-viewer__img')[1].attributes('style')
|
|
|
|
).not.toContain('display: none')
|
|
|
|
})
|
|
|
|
|
2020-08-27 21:22:32 +08:00
|
|
|
test('$attrs', async () => {
|
|
|
|
const alt = 'this ia alt'
|
|
|
|
const wrapper = mount(Image, {
|
|
|
|
props: {
|
|
|
|
src: IMAGE_SUCCESS,
|
|
|
|
alt,
|
|
|
|
referrerpolicy: 'origin',
|
|
|
|
},
|
|
|
|
})
|
2020-09-05 12:17:37 +08:00
|
|
|
await doubleWait()
|
2020-08-27 21:22:32 +08:00
|
|
|
expect(wrapper.find('img').attributes('alt')).toBe(alt)
|
|
|
|
expect(wrapper.find('img').attributes('referrerpolicy')).toBe('origin')
|
|
|
|
})
|
|
|
|
|
2021-09-04 19:29:28 +08:00
|
|
|
test('pass event listeners', async () => {
|
2020-08-27 21:22:32 +08:00
|
|
|
let result = false
|
|
|
|
const wrapper = mount(Image, {
|
|
|
|
props: {
|
|
|
|
src: IMAGE_SUCCESS,
|
2021-09-04 19:29:28 +08:00
|
|
|
onClick: () => (result = true),
|
2020-08-27 21:22:32 +08:00
|
|
|
},
|
|
|
|
})
|
2020-09-05 12:17:37 +08:00
|
|
|
await doubleWait()
|
|
|
|
await wrapper.find('.el-image__inner').trigger('click')
|
2020-08-27 21:22:32 +08:00
|
|
|
expect(result).toBeTruthy()
|
|
|
|
})
|
|
|
|
|
2021-03-26 14:00:19 +08:00
|
|
|
test('emit load event', async () => {
|
|
|
|
const handleLoad = jest.fn()
|
|
|
|
const wrapper = mount(Image, {
|
|
|
|
props: {
|
|
|
|
src: IMAGE_SUCCESS,
|
|
|
|
onLoad: handleLoad,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
await doubleWait()
|
|
|
|
expect(wrapper.find('.el-image__inner').exists()).toBe(true)
|
|
|
|
expect(handleLoad).toBeCalled()
|
|
|
|
})
|
|
|
|
|
2020-08-27 21:22:32 +08:00
|
|
|
//@todo lazy image test
|
|
|
|
})
|