model-pagination-test.js 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362
  1. import Ember from 'ember';
  2. import { module, test } from 'qunit';
  3. import startApp from '../helpers/start-app';
  4. import createUser from '../helpers/create-user';
  5. import { updateObjProps, paginatedJSON, rankJSON, userJSON } from '../helpers/api-mocks';
  6. var application, container, auth;
  7. module('Acceptance: Model Pagination Mixin', {
  8. beforeEach: function() {
  9. application = startApp();
  10. container = application.__container__;
  11. auth = container.lookup('service:auth');
  12. },
  13. afterEach: function() {
  14. Ember.run(application, 'destroy');
  15. Ember.$.mockjax.clear();
  16. }
  17. });
  18. test('pagination redirects from explicit first page', function(assert) {
  19. var user = createUser();
  20. auth.setProperties({
  21. 'isAuthenticated': true,
  22. 'user': user
  23. });
  24. var rank = rankJSON(3, {
  25. 'name': 'Test Rank',
  26. 'slug': 'test-rank',
  27. 'is_tab': true
  28. });
  29. Ember.$.mockjax({
  30. url: '/api/ranks/',
  31. status: 200,
  32. responseText: [rank]
  33. });
  34. var users = [];
  35. for (var i = 1; i <= 20; i++) {
  36. users.push(userJSON(i, { 'rank': rank }));
  37. }
  38. var resultsJSON = paginatedJSON(users, 20, 2, 10, 5);
  39. resultsJSON.users = 10;
  40. Ember.$.mockjax({
  41. url: '/api/users/',
  42. data: {
  43. 'list': 'rank',
  44. 'rank': 'test-rank'
  45. },
  46. status: 200,
  47. responseText: resultsJSON
  48. });
  49. assert.expect(1);
  50. visit('/users/test-rank/1/');
  51. andThen(function() {
  52. assert.equal(currentPath(), 'users.rank.index');
  53. });
  54. });
  55. test('pagination displays next page', function(assert) {
  56. var user = createUser();
  57. auth.setProperties({
  58. 'isAuthenticated': true,
  59. 'user': user
  60. });
  61. var rank = rankJSON(3, {
  62. 'name': 'Test Rank',
  63. 'slug': 'test-rank',
  64. 'is_tab': true
  65. });
  66. Ember.$.mockjax({
  67. url: '/api/ranks/',
  68. status: 200,
  69. responseText: [rank]
  70. });
  71. var users = [];
  72. for (var i = 1; i <= 20; i++) {
  73. users.push(userJSON(i, { 'rank': rank }));
  74. }
  75. var resultsJSON = paginatedJSON(users, 20, 2, 10, 5);
  76. resultsJSON.users = 10;
  77. Ember.$.mockjax({
  78. url: '/api/users/',
  79. data: {
  80. 'list': 'rank',
  81. 'rank': 'test-rank',
  82. 'page': 2,
  83. },
  84. status: 200,
  85. responseText: resultsJSON
  86. });
  87. assert.expect(1);
  88. visit('/users/test-rank/2/');
  89. andThen(function() {
  90. assert.equal(currentPath(), 'users.rank.page');
  91. });
  92. });
  93. test('pagination go to next page', function(assert) {
  94. var user = createUser();
  95. auth.setProperties({
  96. 'isAuthenticated': true,
  97. 'user': user
  98. });
  99. var rank = rankJSON(3, {
  100. 'name': 'Test Rank',
  101. 'slug': 'test-rank',
  102. 'is_tab': true
  103. });
  104. Ember.$.mockjax({
  105. url: '/api/ranks/',
  106. status: 200,
  107. responseText: [rank]
  108. });
  109. var users = [];
  110. for (var i = 1; i <= 20; i++) {
  111. users.push(userJSON(i, { 'rank': rank }));
  112. }
  113. var resultsJSON = paginatedJSON(users, 20, 2, 6, 2);
  114. resultsJSON.users = 10;
  115. Ember.$.mockjax({
  116. url: '/api/users/',
  117. data: {
  118. 'list': 'rank',
  119. 'rank': 'test-rank',
  120. 'page': 2
  121. },
  122. status: 200,
  123. responseText: resultsJSON
  124. });
  125. resultsJSON = paginatedJSON(users, 20, 1, 6, 2);
  126. resultsJSON.users = 10;
  127. Ember.$.mockjax({
  128. url: '/api/users/',
  129. data: {
  130. 'list': 'rank',
  131. 'rank': 'test-rank'
  132. },
  133. status: 200,
  134. responseText: resultsJSON
  135. });
  136. assert.expect(2);
  137. visit('/users/test-rank/');
  138. click('.pager-aligned .btn-next-page:last');
  139. andThen(function() {
  140. assert.equal(currentURL(), '/users/test-rank/2');
  141. assert.equal(currentPath(), 'users.rank.page');
  142. });
  143. });
  144. test('pagination go to last page', function(assert) {
  145. var user = createUser();
  146. auth.setProperties({
  147. 'isAuthenticated': true,
  148. 'user': user
  149. });
  150. var rank = rankJSON(3, {
  151. 'name': 'Test Rank',
  152. 'slug': 'test-rank',
  153. 'is_tab': true
  154. });
  155. Ember.$.mockjax({
  156. url: '/api/ranks/',
  157. status: 200,
  158. responseText: [rank]
  159. });
  160. var users = [];
  161. for (var i = 1; i <= 20; i++) {
  162. users.push(userJSON(i, { 'rank': rank }));
  163. }
  164. var resultsJSON = paginatedJSON(users, 20, 3, 6, 2);
  165. resultsJSON.users = 10;
  166. Ember.$.mockjax({
  167. url: '/api/users/',
  168. data: {
  169. 'list': 'rank',
  170. 'rank': 'test-rank',
  171. 'page': 3
  172. },
  173. status: 200,
  174. responseText: resultsJSON
  175. });
  176. resultsJSON = paginatedJSON(users, 20, 1, 6, 2);
  177. resultsJSON.users = 10;
  178. Ember.$.mockjax({
  179. url: '/api/users/',
  180. data: {
  181. 'list': 'rank',
  182. 'rank': 'test-rank'
  183. },
  184. status: 200,
  185. responseText: resultsJSON
  186. });
  187. assert.expect(2);
  188. visit('/users/test-rank/');
  189. click('.pager-aligned .btn-last-page');
  190. andThen(function() {
  191. assert.equal(currentURL(), '/users/test-rank/3');
  192. assert.equal(currentPath(), 'users.rank.page');
  193. });
  194. });
  195. test('pagination go to previous page', function(assert) {
  196. var user = createUser();
  197. auth.setProperties({
  198. 'isAuthenticated': true,
  199. 'user': user
  200. });
  201. var rank = rankJSON(3, {
  202. 'name': 'Test Rank',
  203. 'slug': 'test-rank',
  204. 'is_tab': true
  205. });
  206. Ember.$.mockjax({
  207. url: '/api/ranks/',
  208. status: 200,
  209. responseText: [rank]
  210. });
  211. var users = [];
  212. for (var i = 1; i <= 20; i++) {
  213. users.push(userJSON(i, { 'rank': rank }));
  214. }
  215. var resultsJSON = paginatedJSON(users, 20, 2, 6, 2);
  216. resultsJSON.users = 10;
  217. Ember.$.mockjax({
  218. url: '/api/users/',
  219. data: {
  220. 'list': 'rank',
  221. 'rank': 'test-rank',
  222. 'page': 2
  223. },
  224. status: 200,
  225. responseText: resultsJSON
  226. });
  227. resultsJSON = paginatedJSON(users, 20, 3, 6, 2);
  228. resultsJSON.users = 10;
  229. Ember.$.mockjax({
  230. url: '/api/users/',
  231. data: {
  232. 'list': 'rank',
  233. 'rank': 'test-rank',
  234. 'page': 3
  235. },
  236. status: 200,
  237. responseText: resultsJSON
  238. });
  239. assert.expect(2);
  240. visit('/users/test-rank/3/');
  241. click('.pager-aligned .btn-previous-page:last');
  242. andThen(function() {
  243. assert.equal(currentURL(), '/users/test-rank/2');
  244. assert.equal(currentPath(), 'users.rank.page');
  245. });
  246. });
  247. test('pagination go to first page', function(assert) {
  248. var user = createUser();
  249. auth.setProperties({
  250. 'isAuthenticated': true,
  251. 'user': user
  252. });
  253. var rank = rankJSON(3, {
  254. 'name': 'Test Rank',
  255. 'slug': 'test-rank',
  256. 'is_tab': true
  257. });
  258. Ember.$.mockjax({
  259. url: '/api/ranks/',
  260. status: 200,
  261. responseText: [rank]
  262. });
  263. var users = [];
  264. for (var i = 1; i <= 20; i++) {
  265. users.push(userJSON(i, { 'rank': rank }));
  266. }
  267. var resultsJSON = paginatedJSON(users, 20, 3, 6, 2);
  268. resultsJSON.users = 10;
  269. Ember.$.mockjax({
  270. url: '/api/users/',
  271. data: {
  272. 'list': 'rank',
  273. 'rank': 'test-rank',
  274. 'page': 3
  275. },
  276. status: 200,
  277. responseText: resultsJSON
  278. });
  279. resultsJSON = paginatedJSON(users, 20, 1, 6, 2);
  280. resultsJSON.users = 10;
  281. Ember.$.mockjax({
  282. url: '/api/users/',
  283. data: {
  284. 'list': 'rank',
  285. 'rank': 'test-rank'
  286. },
  287. status: 200,
  288. responseText: resultsJSON
  289. });
  290. assert.expect(2);
  291. visit('/users/test-rank/3/');
  292. click('.pager-aligned .btn-first-page');
  293. andThen(function() {
  294. assert.equal(currentURL(), '/users/test-rank');
  295. assert.equal(currentPath(), 'users.rank.index');
  296. });
  297. });