diff --git a/test/unit/mocks/uri.js b/test/unit/mocks/uri.js new file mode 100644 index 00000000..ba9a4d31 --- /dev/null +++ b/test/unit/mocks/uri.js @@ -0,0 +1,3 @@ +export const IMAGE_SUCCESS = ''; + +export const IMAGE_FAIL = ''; diff --git a/test/unit/specs/avatar.spec.js b/test/unit/specs/avatar.spec.js index aabcd422..bf5d1599 100644 --- a/test/unit/specs/avatar.spec.js +++ b/test/unit/specs/avatar.spec.js @@ -1,5 +1,6 @@ -import {createTest, createVue, destroyVM} from '../util'; +import { createTest, createVue, destroyVM, wait } from '../util'; import Avatar from 'packages/avatar'; +import { IMAGE_SUCCESS, IMAGE_FAIL } from '../mocks/uri'; describe('Avatar', () => { let vm; @@ -63,18 +64,18 @@ describe('Avatar', () => { it('image avatar', () => { vm = createVue({ template: ` - + ` }, true); const imgElm = vm.$el.children[0]; expect(imgElm.tagName.toUpperCase()).to.equal('IMG'); - expect(imgElm.src).to.equal('https://cube.elemecdn.com/0/88/03b0d39583f48206768a7534e55bcpng.png'); + expect(imgElm.src).to.equal(IMAGE_SUCCESS); }); - it('image fallback', (done) => { + it('image fallback', async() => { vm = createVue({ template: ` - + fallback `, @@ -84,14 +85,12 @@ describe('Avatar', () => { } } }, true); - setTimeout(() => { - const avatarElm = vm.$el; - expect(avatarElm.textContent.trim()).to.equal('fallback'); - done(); - }, 3000); + await wait(); + const avatarElm = vm.$el; + expect(avatarElm.textContent.trim()).to.equal('fallback'); }); - it('image fit', (done) => { + it('image fit', async() => { vm = createVue({ template: `
@@ -103,21 +102,18 @@ describe('Avatar', () => { data() { return { fits: ['fill', 'contain', 'cover', 'none', 'scale-down'], - url: 'https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg' + url: IMAGE_SUCCESS }; } }, true); - setTimeout(() => { - const containerElm = vm.$el; - expect(containerElm.children[0].children[0].style.objectFit).to.equal('cover'); - expect(containerElm.children[1].children[0].style.objectFit).to.equal('fill'); - expect(containerElm.children[2].children[0].style.objectFit).to.equal('contain'); - expect(containerElm.children[3].children[0].style.objectFit).to.equal('cover'); - expect(containerElm.children[4].children[0].style.objectFit).to.equal('none'); - expect(containerElm.children[5].children[0].style.objectFit).to.equal('scale-down'); - - done(); - }, 3000); + await wait(); + const containerElm = vm.$el; + expect(containerElm.children[0].children[0].style.objectFit).to.equal('cover'); + expect(containerElm.children[1].children[0].style.objectFit).to.equal('fill'); + expect(containerElm.children[2].children[0].style.objectFit).to.equal('contain'); + expect(containerElm.children[3].children[0].style.objectFit).to.equal('cover'); + expect(containerElm.children[4].children[0].style.objectFit).to.equal('none'); + expect(containerElm.children[5].children[0].style.objectFit).to.equal('scale-down'); }); }); diff --git a/test/unit/specs/image.spec.js b/test/unit/specs/image.spec.js index e98a8a17..ab6174df 100644 --- a/test/unit/specs/image.spec.js +++ b/test/unit/specs/image.spec.js @@ -1,7 +1,8 @@ import { createTest, createVue, destroyVM, wait } from '../util'; import Image from 'packages/image'; +import { IMAGE_SUCCESS, IMAGE_FAIL } from '../mocks/uri'; -const src = ''; +const src = IMAGE_SUCCESS; describe('Image', () => { let vm; @@ -28,7 +29,9 @@ describe('Image', () => { }); it('load failed', async() => { - vm = createTest(Image, true); + vm = createTest(Image, { + src: IMAGE_FAIL + }, true); await wait(); const error = vm.$el.querySelector('.el-image__error'); expect(error).to.be.exist;