BigW Consortium Gitlab

quick_submit_spec.js 3.9 KB
Newer Older
1
/* eslint-disable space-before-function-paren, no-var, no-return-assign, comma-dangle, jasmine/no-spec-dupes, new-cap, max-len */
Fatih Acet committed
2

3
import '~/behaviors/quick_submit';
Fatih Acet committed
4 5 6 7

(function() {
  describe('Quick Submit behavior', function() {
    var keydownEvent;
8
    preloadFixtures('issues/open-issue.html.raw');
Fatih Acet committed
9
    beforeEach(function() {
10
      loadFixtures('issues/open-issue.html.raw');
Fatih Acet committed
11
      $('form').submit(function(e) {
12
        // Prevent a form submit from moving us off the testing page
Fatih Acet committed
13 14
        return e.preventDefault();
      });
15
      this.spies = {
Fatih Acet committed
16 17
        submit: spyOnEvent('form', 'submit')
      };
18 19

      this.textarea = $('.js-quick-submit textarea').first();
Fatih Acet committed
20 21
    });
    it('does not respond to other keyCodes', function() {
22
      this.textarea.trigger(keydownEvent({
Fatih Acet committed
23 24 25 26 27
        keyCode: 32
      }));
      return expect(this.spies.submit).not.toHaveBeenTriggered();
    });
    it('does not respond to Enter alone', function() {
28
      this.textarea.trigger(keydownEvent({
Fatih Acet committed
29 30 31 32 33 34
        ctrlKey: false,
        metaKey: false
      }));
      return expect(this.spies.submit).not.toHaveBeenTriggered();
    });
    it('does not respond to repeated events', function() {
35
      this.textarea.trigger(keydownEvent({
Fatih Acet committed
36 37 38 39
        repeat: true
      }));
      return expect(this.spies.submit).not.toHaveBeenTriggered();
    });
40 41
    it('disables input of type submit', function() {
      const submitButton = $('.js-quick-submit input[type=submit]');
42
      this.textarea.trigger(keydownEvent());
43

44 45 46
      expect(submitButton).toBeDisabled();
    });
    it('disables button of type submit', function() {
47
      const submitButton = $('.js-quick-submit input[type=submit]');
48
      this.textarea.trigger(keydownEvent());
49

50
      expect(submitButton).toBeDisabled();
Fatih Acet committed
51
    });
52 53 54 55 56 57 58 59 60 61 62 63 64 65
    it('only clicks one submit', function() {
      const existingSubmit = $('.js-quick-submit input[type=submit]');
      // Add an extra submit button
      const newSubmit = $('<button type="submit">Submit it</button>');
      newSubmit.insertAfter(this.textarea);

      const oldClick = spyOnEvent(existingSubmit, 'click');
      const newClick = spyOnEvent(newSubmit, 'click');

      this.textarea.trigger(keydownEvent());

      expect(oldClick).not.toHaveBeenTriggered();
      expect(newClick).toHaveBeenTriggered();
    });
66
    // We cannot stub `navigator.userAgent` for CI's `rake karma` task, so we'll
67
    // only run the tests that apply to the current platform
Fatih Acet committed
68 69
    if (navigator.userAgent.match(/Macintosh/)) {
      it('responds to Meta+Enter', function() {
70
        this.textarea.trigger(keydownEvent());
Fatih Acet committed
71 72 73
        return expect(this.spies.submit).toHaveBeenTriggered();
      });
      it('excludes other modifier keys', function() {
74
        this.textarea.trigger(keydownEvent({
Fatih Acet committed
75 76
          altKey: true
        }));
77
        this.textarea.trigger(keydownEvent({
Fatih Acet committed
78 79
          ctrlKey: true
        }));
80
        this.textarea.trigger(keydownEvent({
Fatih Acet committed
81 82 83 84 85 86
          shiftKey: true
        }));
        return expect(this.spies.submit).not.toHaveBeenTriggered();
      });
    } else {
      it('responds to Ctrl+Enter', function() {
87
        this.textarea.trigger(keydownEvent());
Fatih Acet committed
88 89 90
        return expect(this.spies.submit).toHaveBeenTriggered();
      });
      it('excludes other modifier keys', function() {
91
        this.textarea.trigger(keydownEvent({
Fatih Acet committed
92 93
          altKey: true
        }));
94
        this.textarea.trigger(keydownEvent({
Fatih Acet committed
95 96
          metaKey: true
        }));
97
        this.textarea.trigger(keydownEvent({
Fatih Acet committed
98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118
          shiftKey: true
        }));
        return expect(this.spies.submit).not.toHaveBeenTriggered();
      });
    }
    return keydownEvent = function(options) {
      var defaults;
      if (navigator.userAgent.match(/Macintosh/)) {
        defaults = {
          keyCode: 13,
          metaKey: true
        };
      } else {
        defaults = {
          keyCode: 13,
          ctrlKey: true
        };
      }
      return $.Event('keydown', $.extend({}, defaults, options));
    };
  });
119
}).call(window);