summaryrefslogtreecommitdiff
path: root/spec/javascripts/behaviors/requires_input_spec.js
blob: 3a84013a2ed9dfe5f98d60c8a927978b919182d5 (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
/* eslint-disable space-before-function-paren, no-var */

require('~/behaviors/requires_input');

(function() {
  describe('requiresInput', function() {
    preloadFixtures('branches/new_branch.html.raw');
    beforeEach(function() {
      loadFixtures('branches/new_branch.html.raw');
      this.submitButton = $('button[type="submit"]');
    });
    it('disables submit when any field is required', function() {
      $('.js-requires-input').requiresInput();
      return expect(this.submitButton).toBeDisabled();
    });
    it('enables submit when no field is required', function() {
      $('*[required=required]').removeAttr('required');
      $('.js-requires-input').requiresInput();
      return expect(this.submitButton).not.toBeDisabled();
    });
    it('enables submit when all required fields are pre-filled', function() {
      $('*[required=required]').remove();
      $('.js-requires-input').requiresInput();
      return expect($('.submit')).not.toBeDisabled();
    });
    it('enables submit when all required fields receive input', function() {
      $('.js-requires-input').requiresInput();
      $('#required1').val('input1').change();
      expect(this.submitButton).toBeDisabled();
      $('#optional1').val('input1').change();
      expect(this.submitButton).toBeDisabled();
      $('#required2').val('input2').change();
      $('#required3').val('input3').change();
      $('#required4').val('input4').change();
      $('#required5').val('1').change();
      return expect($('.submit')).not.toBeDisabled();
    });
  });
}).call(window);