summaryrefslogtreecommitdiff
path: root/spec/frontend/blob/blob_file_dropzone_spec.js
blob: 4e9a05418df501417bf8062f11e3f68a27ea5b3e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
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();
    });
  });
});