BigW Consortium Gitlab

issue_spec.js 7.74 KB
Newer Older
1
/* eslint-disable space-before-function-paren, one-var, one-var-declaration-per-line, no-use-before-define, comma-dangle, max-len */
2
import Issue from '~/issue';
3
import CloseReopenReportToggle from '~/close_reopen_report_toggle';
4
import '~/lib/utils/text_utility';
Fatih Acet committed
5

6
describe('Issue', function() {
7
  let $boxClosed, $boxOpen, $btn;
winniehell committed
8

9 10 11
  preloadFixtures('issues/closed-issue.html.raw');
  preloadFixtures('issues/issue-with-task-list.html.raw');
  preloadFixtures('issues/open-issue.html.raw');
12

winniehell committed
13
  function expectErrorMessage() {
14
    const $flashMessage = $('div.flash-alert');
winniehell committed
15 16 17 18 19 20 21 22
    expect($flashMessage).toExist();
    expect($flashMessage).toBeVisible();
    expect($flashMessage).toHaveText('Unable to update this issue at this time.');
  }

  function expectIssueState(isIssueOpen) {
    expectVisibility($boxClosed, !isIssueOpen);
    expectVisibility($boxOpen, isIssueOpen);
23
    expect($btn).toHaveText(isIssueOpen ? 'Close issue' : 'Reopen issue');
winniehell committed
24 25
  }

26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
  function expectNewBranchButtonState(isPending, canCreate) {
    if (Issue.$btnNewBranch.length === 0) {
      return;
    }

    const $available = Issue.$btnNewBranch.find('.available');
    expect($available).toHaveText('New branch');

    if (!isPending && canCreate) {
      expect($available).toBeVisible();
    } else {
      expect($available).toBeHidden();
    }

    const $unavailable = Issue.$btnNewBranch.find('.unavailable');
    expect($unavailable).toHaveText('New branch unavailable');

    if (!isPending && !canCreate) {
      expect($unavailable).toBeVisible();
    } else {
      expect($unavailable).toBeHidden();
    }
winniehell committed
48 49 50 51 52 53 54 55 56 57
  }

  function expectVisibility($element, shouldBeVisible) {
    if (shouldBeVisible) {
      expect($element).not.toHaveClass('hidden');
    } else {
      expect($element).toHaveClass('hidden');
    }
  }

58
  function findElements(isIssueInitiallyOpen) {
59 60 61
    $boxClosed = $('div.status-box-closed');
    expect($boxClosed).toExist();
    expect($boxClosed).toHaveText('Closed');
winniehell committed
62

63 64 65
    $boxOpen = $('div.status-box-open');
    expect($boxOpen).toExist();
    expect($boxOpen).toHaveText('Open');
winniehell committed
66

67 68 69
    $btn = $('.js-issuable-close-button');
    expect($btn).toExist();
    expect($btn).toHaveText(isIssueInitiallyOpen ? 'Close issue' : 'Reopen issue');
winniehell committed
70 71
  }

72 73 74 75 76
  describe('task lists', function() {
    beforeEach(function() {
      loadFixtures('issues/issue-with-task-list.html.raw');
      this.issue = new Issue();
    });
77

78 79 80 81 82
    it('submits an ajax request on tasklist:changed', function() {
      spyOn(jQuery, 'ajax').and.callFake(function(req) {
        expect(req.type).toBe('PATCH');
        expect(req.url).toBe(gl.TEST_HOST + '/frontend-fixtures/issues-project/issues/1.json'); // eslint-disable-line prefer-template
        expect(req.data.issue.description).not.toBe(null);
Fatih Acet committed
83
      });
84 85

      $('.js-task-list-field').trigger('tasklist:changed');
Fatih Acet committed
86 87 88
    });
  });

89 90 91 92 93 94 95 96 97
  [true, false].forEach((isIssueInitiallyOpen) => {
    describe(`with ${isIssueInitiallyOpen ? 'open' : 'closed'} issue`, function() {
      const action = isIssueInitiallyOpen ? 'close' : 'reopen';

      function ajaxSpy(req) {
        if (req.url === this.$triggeredButton.attr('href')) {
          expect(req.type).toBe('PUT');
          expectNewBranchButtonState(true, false);
          return this.issueStateDeferred;
98 99
        } else if (req.url === Issue.createMrDropdownWrap.dataset.canCreatePath) {
          expect(req.type).toBe('GET');
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
          expectNewBranchButtonState(true, false);
          return this.canCreateBranchDeferred;
        }

        expect(req.url).toBe('unexpected');
        return null;
      }

      beforeEach(function() {
        if (isIssueInitiallyOpen) {
          loadFixtures('issues/open-issue.html.raw');
        } else {
          loadFixtures('issues/closed-issue.html.raw');
        }

115
        findElements(isIssueInitiallyOpen);
116 117
        this.issue = new Issue();
        expectIssueState(isIssueInitiallyOpen);
118 119

        this.$triggeredButton = $btn;
120 121 122 123 124 125 126 127 128

        this.$projectIssuesCounter = $('.issue_counter');
        this.$projectIssuesCounter.text('1,001');

        this.issueStateDeferred = new jQuery.Deferred();
        this.canCreateBranchDeferred = new jQuery.Deferred();

        spyOn(jQuery, 'ajax').and.callFake(ajaxSpy.bind(this));
      });
winniehell committed
129

130 131 132
      it(`${action}s the issue`, function() {
        this.$triggeredButton.trigger('click');
        this.issueStateDeferred.resolve({
Fatih Acet committed
133 134
          id: 34
        });
135 136 137
        this.canCreateBranchDeferred.resolve({
          can_create_branch: !isIssueInitiallyOpen
        });
winniehell committed
138

139
        expectIssueState(!isIssueInitiallyOpen);
140
        expect(this.$triggeredButton.get(0).getAttribute('disabled')).toBeNull();
141 142 143
        expect(this.$projectIssuesCounter.text()).toBe(isIssueInitiallyOpen ? '1,000' : '1,002');
        expectNewBranchButtonState(false, !isIssueInitiallyOpen);
      });
winniehell committed
144

145 146 147
      it(`fails to ${action} the issue if saved:false`, function() {
        this.$triggeredButton.trigger('click');
        this.issueStateDeferred.resolve({
Fatih Acet committed
148 149
          saved: false
        });
150 151 152
        this.canCreateBranchDeferred.resolve({
          can_create_branch: isIssueInitiallyOpen
        });
winniehell committed
153

154
        expectIssueState(isIssueInitiallyOpen);
155
        expect(this.$triggeredButton.get(0).getAttribute('disabled')).toBeNull();
156 157 158
        expectErrorMessage();
        expect(this.$projectIssuesCounter.text()).toBe('1,001');
        expectNewBranchButtonState(false, isIssueInitiallyOpen);
Fatih Acet committed
159
      });
winniehell committed
160

161 162 163 164 165
      it(`fails to ${action} the issue if HTTP error occurs`, function() {
        this.$triggeredButton.trigger('click');
        this.issueStateDeferred.reject();
        this.canCreateBranchDeferred.resolve({
          can_create_branch: isIssueInitiallyOpen
166 167
        });

168
        expectIssueState(isIssueInitiallyOpen);
169
        expect(this.$triggeredButton.get(0).getAttribute('disabled')).toBeNull();
170 171 172 173
        expectErrorMessage();
        expect(this.$projectIssuesCounter.text()).toBe('1,001');
        expectNewBranchButtonState(false, isIssueInitiallyOpen);
      });
winniehell committed
174

175 176 177 178
      it('disables the new branch button if Ajax call fails', function() {
        this.$triggeredButton.trigger('click');
        this.issueStateDeferred.reject();
        this.canCreateBranchDeferred.reject();
winniehell committed
179

180
        expectNewBranchButtonState(false, false);
Fatih Acet committed
181
      });
winniehell committed
182

183 184 185
      it('does not trigger Ajax call if new branch button is missing', function() {
        Issue.$btnNewBranch = $();
        this.canCreateBranchDeferred = null;
winniehell committed
186

187 188 189
        this.$triggeredButton.trigger('click');
        this.issueStateDeferred.reject();
      });
Fatih Acet committed
190 191
    });
  });
Luke "Jared" Bennett committed
192 193 194 195 196 197 198 199 200 201 202 203 204

  describe('units', () => {
    describe('class constructor', () => {
      it('calls .initCloseReopenReport', () => {
        spyOn(Issue.prototype, 'initCloseReopenReport');

        new Issue(); // eslint-disable-line no-new

        expect(Issue.prototype.initCloseReopenReport).toHaveBeenCalled();
      });
    });

    describe('initCloseReopenReport', () => {
205
      it('calls .initDroplab', () => {
Luke "Jared" Bennett committed
206 207 208 209 210 211
        const container = jasmine.createSpyObj('container', ['querySelector']);
        const dropdownTrigger = {};
        const dropdownList = {};
        const button = {};

        spyOn(document, 'querySelector').and.returnValue(container);
212
        spyOn(CloseReopenReportToggle.prototype, 'initDroplab');
Luke "Jared" Bennett committed
213 214 215 216 217 218 219 220
        container.querySelector.and.returnValues(dropdownTrigger, dropdownList, button);

        Issue.prototype.initCloseReopenReport();

        expect(document.querySelector).toHaveBeenCalledWith('.js-issuable-close-dropdown');
        expect(container.querySelector).toHaveBeenCalledWith('.js-issuable-close-toggle');
        expect(container.querySelector).toHaveBeenCalledWith('.js-issuable-close-menu');
        expect(container.querySelector).toHaveBeenCalledWith('.js-issuable-close-button');
221
        expect(CloseReopenReportToggle.prototype.initDroplab).toHaveBeenCalled();
Luke "Jared" Bennett committed
222 223 224
      });
    });
  });
225
});