image-viewer.test.tsx 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import { nextTick } from 'vue'
  2. import { mount } from '@vue/test-utils'
  3. import { describe, expect, test } from 'vitest'
  4. import { IMAGE_SUCCESS } from '@element-plus/test-utils/mock'
  5. import ImageViewer from '../src/image-viewer.vue'
  6. async function doubleWait() {
  7. await nextTick()
  8. await nextTick()
  9. }
  10. describe('<image-viewer />', () => {
  11. test('big image preview', async () => {
  12. const wrapper = mount(<ImageViewer urlList={[IMAGE_SUCCESS]} />)
  13. await doubleWait()
  14. const viewer = wrapper.find('.el-image-viewer__wrapper')
  15. expect(viewer.exists()).toBe(true)
  16. await wrapper.find('.el-image-viewer__close').trigger('click')
  17. expect(wrapper.emitted('close')).toEqual([[]])
  18. wrapper.unmount()
  19. })
  20. test('image preview hide-click-on-modal', async () => {
  21. const wrapper = mount(<ImageViewer urlList={[IMAGE_SUCCESS]} />)
  22. await doubleWait()
  23. const viewer = wrapper.find('.el-image-viewer__wrapper')
  24. expect(viewer.exists()).toBe(true)
  25. await wrapper.find('.el-image-viewer__mask').trigger('click')
  26. expect(wrapper.emitted('close')).toBeUndefined()
  27. await wrapper.setProps({
  28. hideOnClickModal: true,
  29. })
  30. await wrapper.find('.el-image-viewer__mask').trigger('click')
  31. expect(wrapper.emitted('close')).toBeDefined()
  32. wrapper.unmount()
  33. })
  34. test('manually switch image', async () => {
  35. const wrapper = mount(
  36. <ImageViewer urlList={[IMAGE_SUCCESS, IMAGE_SUCCESS]} />
  37. )
  38. await doubleWait()
  39. const viewer = wrapper.find('.el-image-viewer__wrapper')
  40. expect(viewer.exists()).toBe(true)
  41. const imgList = wrapper.findAll('.el-image-viewer__img')
  42. expect(imgList[0].attributes('style')).not.contains('display: none;')
  43. expect(imgList[1].attributes('style')).contains('display: none;')
  44. wrapper.vm.setActiveItem(1)
  45. await doubleWait()
  46. expect(imgList[0].attributes('style')).contains('display: none;')
  47. expect(imgList[1].attributes('style')).not.contains('display: none;')
  48. wrapper.unmount()
  49. })
  50. })