mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-05 19:41:42 +08:00
540 lines
12 KiB
JavaScript
540 lines
12 KiB
JavaScript
import Uploader from '..';
|
|
import { mount, later, triggerDrag } from '../../../test';
|
|
|
|
window.File = function () {
|
|
this.size = 10000;
|
|
};
|
|
|
|
const mockFileDataUrl = 'data:image/test';
|
|
const mockFile = new File([], 'test.jpg');
|
|
const file = { target: { files: [mockFile] } };
|
|
const multiFile = { target: { files: [mockFile, mockFile] } };
|
|
const IMAGE = 'https://img01.yzcdn.cn/vant/cat.jpeg';
|
|
const PDF = 'https://img01.yzcdn.cn/vant/test.pdf';
|
|
|
|
window.FileReader = function () {
|
|
this.readAsText = function () {
|
|
this.onload &&
|
|
this.onload({
|
|
target: {
|
|
result: mockFileDataUrl,
|
|
},
|
|
});
|
|
};
|
|
this.readAsDataURL = this.readAsText;
|
|
};
|
|
|
|
test('disabled', () => {
|
|
const afterRead = jest.fn();
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
disabled: true,
|
|
afterRead,
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
expect(afterRead).toHaveBeenCalledTimes(0);
|
|
});
|
|
|
|
test('result-type as text', (done) => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
resultType: 'text',
|
|
afterRead: (readFile) => {
|
|
expect(readFile.content).toEqual(mockFileDataUrl);
|
|
done();
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
});
|
|
|
|
test('result-type as file', (done) => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
resultType: 'file',
|
|
afterRead: (readFile) => {
|
|
expect(readFile.file).toBeTruthy();
|
|
expect(readFile.content).toBeFalsy();
|
|
done();
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
});
|
|
|
|
test('set input name', (done) => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
name: 'uploader',
|
|
beforeRead: (readFile, detail) => {
|
|
expect(detail.name).toEqual('uploader');
|
|
return true;
|
|
},
|
|
afterRead: (readFile, detail) => {
|
|
expect(detail.name).toEqual('uploader');
|
|
done();
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
});
|
|
|
|
test('unknown resultType', () => {
|
|
const afterRead = jest.fn();
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
resultType: 'xxxx',
|
|
afterRead,
|
|
},
|
|
});
|
|
wrapper.vm.onChange(file);
|
|
expect(afterRead).toHaveBeenCalledTimes(0);
|
|
});
|
|
|
|
test('before read return false', () => {
|
|
const afterRead = jest.fn();
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
beforeRead: () => false,
|
|
afterRead,
|
|
},
|
|
});
|
|
|
|
const input = wrapper.find('input');
|
|
|
|
wrapper.vm.onChange(file);
|
|
expect(afterRead).toHaveBeenCalledTimes(0);
|
|
expect(input.element.value).toEqual('');
|
|
});
|
|
|
|
test('before read return promise and resolve', async () => {
|
|
const afterRead = jest.fn();
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
beforeRead: () =>
|
|
new Promise((resolve) => {
|
|
resolve(file);
|
|
}),
|
|
afterRead,
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
|
|
await later();
|
|
expect(afterRead).toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
test('before read return promise and resolve no value', async () => {
|
|
const afterRead = jest.fn();
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
beforeRead: () =>
|
|
new Promise((resolve) => {
|
|
resolve();
|
|
}),
|
|
afterRead,
|
|
},
|
|
});
|
|
|
|
const input = wrapper.find('input');
|
|
wrapper.vm.onChange(file);
|
|
await later();
|
|
expect(afterRead).toHaveBeenCalledTimes(1);
|
|
expect(input.element.value).toEqual('');
|
|
});
|
|
|
|
test('before read return promise and reject', async () => {
|
|
const afterRead = jest.fn();
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
beforeRead: () =>
|
|
new Promise((resolve, reject) => {
|
|
reject();
|
|
}),
|
|
afterRead,
|
|
},
|
|
});
|
|
|
|
const input = wrapper.find('input');
|
|
wrapper.vm.onChange(file);
|
|
|
|
await later();
|
|
expect(afterRead).toHaveBeenCalledTimes(0);
|
|
expect(input.element.value).toEqual('');
|
|
});
|
|
|
|
test('file size overlimit', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
maxSize: 1,
|
|
},
|
|
});
|
|
wrapper.vm.onChange(file);
|
|
wrapper.vm.onChange(multiFile);
|
|
|
|
await later();
|
|
expect(wrapper.emitted('oversize')[0]).toBeTruthy();
|
|
expect(wrapper.emitted('oversize')[1]).toBeTruthy();
|
|
|
|
wrapper.vm.maxSize = 100000;
|
|
wrapper.vm.onChange(multiFile);
|
|
|
|
await later();
|
|
expect(wrapper.emitted('oversize')[2]).toBeFalsy();
|
|
});
|
|
|
|
test('render upload-text', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
uploadText: 'Text',
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('render preview image', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [
|
|
{ url: 'https://img01.yzcdn.cn/vant/cat.jpeg' },
|
|
{ url: 'https://img01.yzcdn.cn/vant/test.pdf' },
|
|
{ file: { name: 'test.pdf' } },
|
|
],
|
|
},
|
|
listeners: {
|
|
input(fileList) {
|
|
wrapper.setProps({ fileList });
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
await later();
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('image-fit prop', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
imageFit: 'contain',
|
|
fileList: [{ url: 'https://img01.yzcdn.cn/vant/cat.jpeg' }],
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('upload-icon prop', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
uploadIcon: 'add',
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('disable preview image', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [],
|
|
previewImage: false,
|
|
},
|
|
listeners: {
|
|
input(fileList) {
|
|
wrapper.setProps({ fileList });
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
await later();
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('max-count prop', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [],
|
|
maxCount: 1,
|
|
},
|
|
listeners: {
|
|
input(fileList) {
|
|
wrapper.setProps({ fileList });
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(multiFile);
|
|
await later();
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('preview-size prop', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [],
|
|
previewSize: 30,
|
|
},
|
|
listeners: {
|
|
input(fileList) {
|
|
wrapper.setProps({ fileList });
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
await later();
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('deletable prop', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }],
|
|
},
|
|
});
|
|
|
|
expect(wrapper.find('.van-uploader__preview-delete').element).toBeTruthy();
|
|
|
|
wrapper.setProps({ deletable: false });
|
|
expect(wrapper.find('.van-uploader__preview-delete').element).toBeFalsy();
|
|
});
|
|
|
|
test('delete preview image', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }],
|
|
previewSize: 30,
|
|
},
|
|
listeners: {
|
|
input(fileList) {
|
|
wrapper.setProps({ fileList });
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-uploader__preview-delete').trigger('click');
|
|
expect(wrapper.vm.fileList.length).toEqual(0);
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
expect(wrapper.emitted('delete')[0]).toBeTruthy();
|
|
});
|
|
|
|
test('before-delete prop return false', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }],
|
|
beforeDelete: () => false,
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-uploader__preview-delete').trigger('click');
|
|
expect(wrapper.emitted('delete')).toBeFalsy();
|
|
});
|
|
|
|
test('before-delete prop return true', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }],
|
|
beforeDelete: () => true,
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-uploader__preview-delete').trigger('click');
|
|
expect(wrapper.emitted('delete')).toBeTruthy();
|
|
});
|
|
|
|
test('before-delete prop resolved', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }],
|
|
beforeDelete: () => new Promise((resolve) => resolve()),
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-uploader__preview-delete').trigger('click');
|
|
await later();
|
|
expect(wrapper.emitted('delete')).toBeTruthy();
|
|
});
|
|
|
|
test('before-delete prop rejected', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }],
|
|
beforeDelete: () => new Promise((resolve, reject) => reject()),
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-uploader__preview-delete').trigger('click');
|
|
await later();
|
|
expect(wrapper.emitted('delete')).toBeFalsy();
|
|
});
|
|
|
|
test('click to preview image', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
previewFullImage: false,
|
|
fileList: [{ url: IMAGE }, { url: PDF }],
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-image').trigger('click');
|
|
const imagePreviewNode = document.querySelector('.van-image-preview');
|
|
expect(imagePreviewNode).toBeFalsy();
|
|
|
|
wrapper.setProps({ previewFullImage: true });
|
|
wrapper.find('.van-image').trigger('click');
|
|
|
|
await later();
|
|
|
|
const imagePreviewNode2 = document.querySelector('.van-image-preview');
|
|
const images = imagePreviewNode2.querySelectorAll(
|
|
'.van-image-preview__image'
|
|
);
|
|
expect(images.length).toEqual(1);
|
|
});
|
|
|
|
test('preview-options prop', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }],
|
|
previewOptions: {
|
|
closeable: true,
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-image').trigger('click');
|
|
await later();
|
|
|
|
const closeIcon = document.querySelectorAll('.van-image-preview__close-icon');
|
|
expect(closeIcon.length).toEqual(1);
|
|
});
|
|
|
|
test('closeImagePreview method', () => {
|
|
const close = jest.fn();
|
|
const wrapper = mount(Uploader, {
|
|
mocks: {
|
|
imagePreview: {
|
|
close,
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.closeImagePreview();
|
|
expect(close).toHaveBeenCalledTimes(1);
|
|
|
|
// should not throw error
|
|
const wrapper2 = mount(Uploader);
|
|
wrapper2.vm.closeImagePreview();
|
|
});
|
|
|
|
test('click-preview event', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
previewFullImage: false,
|
|
fileList: [{ url: IMAGE }, { url: PDF }],
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-image').trigger('click');
|
|
expect(wrapper.emitted('click-preview')[0][0]).toEqual({ url: IMAGE });
|
|
expect(wrapper.emitted('click-preview')[0][1]).toEqual({
|
|
name: '',
|
|
index: 0,
|
|
});
|
|
});
|
|
|
|
test('close-preview event', async () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }],
|
|
},
|
|
});
|
|
|
|
wrapper.find('.van-image').trigger('click');
|
|
|
|
const preview = document.querySelector('.van-image-preview');
|
|
const swipe = preview.querySelector('.van-swipe-item');
|
|
triggerDrag(swipe, 0, 0);
|
|
|
|
await later(300);
|
|
expect(wrapper.emitted('close-preview')).toBeTruthy();
|
|
});
|
|
|
|
test('show-upload prop', () => {
|
|
const wrapper = mount(Uploader);
|
|
expect(wrapper.contains('.van-uploader__upload')).toBeTruthy();
|
|
wrapper.setProps({ showUpload: false });
|
|
expect(wrapper.contains('.van-uploader__upload')).toBeFalsy();
|
|
});
|
|
|
|
test('file message should be reactive', (done) => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [],
|
|
afterRead(file) {
|
|
file.status = 'uploading';
|
|
file.message = 1;
|
|
setTimeout(() => {
|
|
file.message = 2;
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
done();
|
|
});
|
|
},
|
|
},
|
|
listeners: {
|
|
input(fileList) {
|
|
wrapper.setProps({ fileList });
|
|
},
|
|
},
|
|
});
|
|
|
|
wrapper.vm.onChange(file);
|
|
});
|
|
|
|
test('multiFile upload filter max-size file', async () => {
|
|
const SmallFile = function () {
|
|
this.size = 100;
|
|
};
|
|
const multiFiles = {
|
|
target: { files: [mockFile, new SmallFile([], 'small-test.jpg')] },
|
|
};
|
|
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
maxSize: 1000,
|
|
},
|
|
});
|
|
wrapper.vm.onChange(multiFiles);
|
|
|
|
await later();
|
|
|
|
expect(wrapper.emitted('oversize')[0]).toBeTruthy();
|
|
});
|
|
|
|
test('preview-cover slot', () => {
|
|
const wrapper = mount(Uploader, {
|
|
props: {
|
|
fileList: [{ url: IMAGE }, { url: IMAGE }],
|
|
},
|
|
slots: {
|
|
'preview-cover': (item) => `url: ${item.url}, index: ${item.index}`,
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|