51 lines
1.3 KiB
JavaScript
51 lines
1.3 KiB
JavaScript
|
import $ from 'jquery';
|
||
|
import BlobFileDropzone from '~/blob/blob_file_dropzone';
|
||
|
|
||
|
describe('BlobFileDropzone', () => {
|
||
|
preloadFixtures('blob/show.html');
|
||
|
let dropzone;
|
||
|
let replaceFileButton;
|
||
|
const jQueryMock = {
|
||
|
enable: jest.fn(),
|
||
|
disable: jest.fn(),
|
||
|
};
|
||
|
|
||
|
beforeEach(() => {
|
||
|
loadFixtures('blob/show.html');
|
||
|
const form = $('.js-upload-blob-form');
|
||
|
// eslint-disable-next-line no-new
|
||
|
new BlobFileDropzone(form, 'POST');
|
||
|
dropzone = $('.js-upload-blob-form .dropzone').get(0).dropzone;
|
||
|
dropzone.processQueue = jest.fn();
|
||
|
replaceFileButton = $('#submit-all');
|
||
|
$.fn.extend(jQueryMock);
|
||
|
});
|
||
|
|
||
|
describe('submit button', () => {
|
||
|
it('requires file', () => {
|
||
|
jest.spyOn(window, 'alert').mockImplementation(() => {});
|
||
|
|
||
|
replaceFileButton.click();
|
||
|
|
||
|
expect(window.alert).toHaveBeenCalled();
|
||
|
});
|
||
|
|
||
|
it('is disabled while uploading', () => {
|
||
|
jest.spyOn(window, 'alert').mockImplementation(() => {});
|
||
|
|
||
|
const file = new File([], 'some-file.jpg');
|
||
|
const fakeEvent = $.Event('drop', {
|
||
|
dataTransfer: { files: [file] },
|
||
|
});
|
||
|
|
||
|
dropzone.listeners[0].events.drop(fakeEvent);
|
||
|
|
||
|
replaceFileButton.click();
|
||
|
|
||
|
expect(window.alert).not.toHaveBeenCalled();
|
||
|
expect(jQueryMock.enable).toHaveBeenCalled();
|
||
|
expect(dropzone.processQueue).toHaveBeenCalled();
|
||
|
});
|
||
|
});
|
||
|
});
|