signin-modal.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. (function () {
  2. 'use strict';
  3. var app = null;
  4. QUnit.acceptance("Sign In", {
  5. beforeEach: function() {
  6. $('#hidden-login-form').on('submit.stopInTest', function(event) {
  7. event.stopPropagation();
  8. return false;
  9. });
  10. app = initTestMisago();
  11. },
  12. afterEach: function() {
  13. $('#hidden-login-form').off('submit.stopInTest');
  14. app.destroy();
  15. }
  16. });
  17. QUnit.test('with empty credentials', function(assert) {
  18. var done = assert.async();
  19. waitForElement('.navbar .nav-guest .btn-default');
  20. click('.navbar .nav-guest .btn-default');
  21. waitForElement('.modal-signin');
  22. click('.modal-signin .btn-primary');
  23. onElement('.alerts .alert-danger', function() {
  24. assert.equal(getAlertMessage(), "Fill out both fields.",
  25. "login form raised alert about empty inputs.");
  26. done();
  27. });
  28. });
  29. QUnit.test('with backend error', function(assert) {
  30. $.mockjax({
  31. url: '/test-api/auth/',
  32. status: 500
  33. });
  34. var done = assert.async();
  35. waitForElement('.navbar .nav-guest .btn-default');
  36. click('.navbar .nav-guest .btn-default');
  37. waitForElement('.modal-signin');
  38. fillIn('.modal-signin .form-group:first-child input', 'SomeFake');
  39. fillIn('.modal-signin .form-group:last-child input', 'pass1234');
  40. click('.modal-signin .btn-primary');
  41. onElement('.alerts .alert-danger', function() {
  42. assert.equal(getAlertMessage(), "Unknown error has occured.",
  43. "login form raised alert about backend error.");
  44. done();
  45. });
  46. });
  47. QUnit.test('with invalid credentials', function(assert) {
  48. var message = 'Login or password is incorrect.';
  49. $.mockjax({
  50. url: '/test-api/auth/',
  51. status: 400,
  52. responseText: {
  53. 'detail': message,
  54. 'code': 'invalid_login'
  55. }
  56. });
  57. var done = assert.async();
  58. waitForElement('.navbar .nav-guest .btn-default');
  59. click('.navbar .nav-guest .btn-default');
  60. waitForElement('.modal-signin');
  61. fillIn('.modal-signin .form-group:first-child input', 'SomeFake');
  62. fillIn('.modal-signin .form-group:last-child input', 'pass1234');
  63. click('.modal-signin .btn-primary');
  64. onElement('.alerts .alert-danger', function() {
  65. assert.equal(getAlertMessage(), message,
  66. "login form raised alert about invalid credentials.");
  67. done();
  68. });
  69. });
  70. QUnit.test('to banned account', function(assert) {
  71. $.mockjax({
  72. url: '/test-api/auth/',
  73. status: 400,
  74. responseText: {
  75. 'detail': {
  76. 'expires_on': null,
  77. 'message': {
  78. 'plain': 'You are banned for trolling.',
  79. 'html': '<p>You are banned for trolling.</p>',
  80. }
  81. },
  82. 'code': 'banned'
  83. }
  84. });
  85. var done = assert.async();
  86. waitForElement('.navbar .nav-guest .btn-default');
  87. click('.navbar .nav-guest .btn-default');
  88. waitForElement('.modal-signin');
  89. fillIn('.modal-signin .form-group:first-child input', 'SomeFake');
  90. fillIn('.modal-signin .form-group:last-child input', 'pass1234');
  91. click('.modal-signin .btn-primary');
  92. onElement('.page-error-banned .lead', function() {
  93. assert.equal(
  94. getElementText('.page .error-message .lead'),
  95. "You are banned for trolling.",
  96. "login form displayed error banned page with ban message.");
  97. waitForElementRemoval('.modal-signin');
  98. then(function() {
  99. assert.ok(true, "signin modal was closed.");
  100. done();
  101. });
  102. });
  103. });
  104. QUnit.test('success', function(assert) {
  105. $.mockjax({
  106. url: '/test-api/auth/',
  107. status: 200,
  108. responseText: {
  109. 'detail': 'ok'
  110. }
  111. });
  112. var done = assert.async();
  113. waitForElement('.navbar .nav-guest .btn-default');
  114. click('.navbar .nav-guest .btn-default');
  115. waitForElement('.modal-signin');
  116. fillIn('.modal-signin .form-group:first-child input', 'SomeFake');
  117. fillIn('.modal-signin .form-group:last-child input', 'pass1234');
  118. click('.modal-signin .btn-primary');
  119. var $form = $('#hidden-login-form');
  120. $form.on('submit.stopInTest', function(event) {
  121. event.stopPropagation();
  122. assert.ok(true, 'login form was submit');
  123. assert.equal($form.find('input[name="username"]').val(), 'SomeFake',
  124. "hidden form was filled with valid username.");
  125. assert.equal($form.find('input[name="password"]').val(), 'pass1234',
  126. "hidden form was filled with valid password.");
  127. done();
  128. return false;
  129. });
  130. });
  131. }());