summaryrefslogtreecommitdiff
path: root/tests/frontend/specs/automatic_reconnect.js
blob: e2d2df36a4d8592a30858fa06d39d1ba810094a0 (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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
describe('Automatic pad reload on Force Reconnect message', function() {
  var padId, $originalPadFrame;

  beforeEach(function(done) {
    padId = helper.newPad(function() {
      // enable userdup error to have timer to force reconnect
      var $errorMessageModal = helper.padChrome$('#connectivity .userdup');
      $errorMessageModal.addClass('with_reconnect_timer');

      // make sure there's a timeout set, otherwise automatic reconnect won't be enabled
      helper.padChrome$.window.clientVars.automaticReconnectionTimeout = 2;

      // open same pad on another iframe, to force userdup error
      var $otherIframeWithSamePad = $('<iframe src="/p/' + padId + '" style="height: 1px;"></iframe>');
      $originalPadFrame = $('#iframe-container iframe');
      $otherIframeWithSamePad.insertAfter($originalPadFrame);

      // wait for modal to be displayed
      helper.waitFor(function() {
        return $errorMessageModal.is(':visible');
      }, 50000).done(done);
    });

    this.timeout(60000);
  });

  it('displays a count down timer to automatically reconnect', function(done) {
    var $errorMessageModal = helper.padChrome$('#connectivity .userdup');
    var $countDownTimer = $errorMessageModal.find('.reconnecttimer');

    expect($countDownTimer.is(':visible')).to.be(true);

    done();
  });

  context('and user clicks on Cancel', function() {
    beforeEach(function() {
      var $errorMessageModal = helper.padChrome$('#connectivity .userdup');
      $errorMessageModal.find('#cancelreconnect').click();
    });

    it('does not show Cancel button nor timer anymore', function(done) {
      var $errorMessageModal = helper.padChrome$('#connectivity .userdup');
      var $countDownTimer = $errorMessageModal.find('.reconnecttimer');
      var $cancelButton = $errorMessageModal.find('#cancelreconnect');

      expect($countDownTimer.is(':visible')).to.be(false);
      expect($cancelButton.is(':visible')).to.be(false);

      done();
    });
  });

  context('and user does not click on Cancel until timer expires', function() {
    var padWasReloaded = false;

    beforeEach(function() {
      $originalPadFrame.one('load', function() {
        padWasReloaded = true;
      });
    });

    it('reloads the pad', function(done) {
      helper.waitFor(function() {
        return padWasReloaded;
      }, 5000).done(done);

      this.timeout(5000);
    });
  });
});