pagination.spec.js 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  1. import { createTest, createVue, triggerEvent } from '../util';
  2. import Pagination from 'packages/pagination';
  3. describe('Pagination', () => {
  4. it('create', () => {
  5. const vm = createTest(Pagination);
  6. const elm = vm.$el;
  7. // prev
  8. expect(elm.querySelector('button.btn-prev')).to.exist;
  9. // pager
  10. expect(elm.querySelector('ul.el-pager')).to.exist;
  11. // next
  12. expect(elm.querySelector('button.btn-next')).to.exist;
  13. // jumper
  14. expect(elm.querySelector('.el-pagination__jump')).to.exist;
  15. // ->
  16. expect(elm.querySelector('.el-pagination__rightwrapper')).to.exist;
  17. // total
  18. expect(elm.querySelector('.el-pagination__total')).to.exist;
  19. });
  20. it('set layout', () => {
  21. const vm = createTest(Pagination, {
  22. layout: 'prev, pager, next'
  23. });
  24. const elm = vm.$el;
  25. // prev
  26. expect(elm.querySelector('button.btn-prev')).to.exist;
  27. // pager
  28. expect(elm.querySelector('ul.el-pager')).to.exist;
  29. // next
  30. expect(elm.querySelector('button.btn-next')).to.exist;
  31. // not found jumper
  32. expect(elm.querySelector('.el-pagination__jump')).to.not.exist;
  33. // not found ->
  34. expect(elm.querySelector('.el-pagination__rightwrapper')).to.not.exist;
  35. // not found total
  36. expect(elm.querySelector('.el-pagination__total')).to.not.exist;
  37. });
  38. it('small', () => {
  39. const vm = createTest(Pagination, {
  40. small: true
  41. });
  42. expect(vm.$el.classList.contains('el-pagination--small')).to.true;
  43. });
  44. it('pageSize', () => {
  45. const vm = createTest(Pagination, {
  46. pageSize: 25,
  47. total: 100
  48. });
  49. expect(vm.$el.querySelectorAll('li.number')).to.length(4);
  50. });
  51. it('currentPage', () => {
  52. const vm = createTest(Pagination, {
  53. pageSize: 20,
  54. total: 200,
  55. currentPage: 3
  56. });
  57. expect(vm.$el.querySelector('li.number.active')).to.have.property('textContent').to.equal('3');
  58. });
  59. it('pageSizes', () => {
  60. const vm = createTest(Pagination, {
  61. pageSizes: [10, 15, 35, 50],
  62. pageSize: 35,
  63. total: 1000,
  64. layout: 'sizes, prev, pager, next'
  65. });
  66. expect(vm.$el.querySelector('.el-select-dropdown__item.selected')).to.property('textContent').include('35');
  67. expect([].slice.call(vm.$el.querySelectorAll('.el-select-dropdown__item'))
  68. .map(node => parseInt(node.textContent, 10)))
  69. .to.deep.equal([10, 15, 35, 50]);
  70. });
  71. it('pageSizes:not found pageSize', () => {
  72. const vm = createTest(Pagination, {
  73. pageSizes: [10, 15, 35, 50],
  74. pageSize: 24,
  75. total: 1000,
  76. layout: 'sizes, prev, pager, next'
  77. });
  78. expect(vm.$el.querySelector('.el-select-dropdown__item.selected')).to.property('textContent').include('10');
  79. });
  80. it('layout is empty', () => {
  81. const vm = createTest(Pagination, {
  82. layout: ''
  83. });
  84. expect(vm.$el.textContent).to.empty;
  85. });
  86. it('jumper: change value', () => {
  87. const vm = createVue({
  88. template: `
  89. <el-pagination
  90. @current-change="handleChange"
  91. :page-size="10"
  92. :total="100" />
  93. `,
  94. methods: {
  95. handleChange(val) {
  96. this.page = val;
  97. }
  98. },
  99. data() {
  100. return { page: 0 };
  101. }
  102. }, true);
  103. const input = vm.$el.querySelector('.el-pagination__jump input');
  104. input.focus();
  105. input.value = -1;
  106. triggerEvent(input, 'change');
  107. expect(vm.page).to.equal(1);
  108. input.value = 10000;
  109. triggerEvent(input, 'change');
  110. expect(vm.page).to.equal(10);
  111. input.value = '我好帅';
  112. triggerEvent(input, 'change');
  113. expect(vm.page).to.equal(1);
  114. });
  115. it('event:current-change', () => {
  116. const vm = createVue({
  117. template: `
  118. <el-pagination
  119. :total="1000"
  120. @current-change="change = true" />
  121. `,
  122. data() {
  123. return { change: false };
  124. }
  125. });
  126. const next = vm.$el.querySelector('button.btn-next');
  127. const prev = vm.$el.querySelector('button.btn-prev');
  128. expect(vm.change).to.false;
  129. // click 9
  130. let count = 9;
  131. while (--count) {
  132. next.click();
  133. }
  134. prev.click();
  135. expect(vm.change).to.true;
  136. });
  137. it('event:size-change', done => {
  138. const vm = createVue({
  139. template: `
  140. <el-pagination
  141. :total="100"
  142. layout="sizes, prev, pager, next"
  143. @size-change="trigger = true"
  144. :pageSize="10" />
  145. `,
  146. data() {
  147. return { trigger: false };
  148. }
  149. });
  150. expect(vm.trigger).to.false;
  151. vm.$el.querySelectorAll('li.el-select-dropdown__item')[1].click();
  152. setTimeout(_ => {
  153. expect(vm.trigger).to.true;
  154. done();
  155. }, 50);
  156. });
  157. it('pageSize > total', () => {
  158. const vm = createVue({
  159. template: `
  160. <el-pagination
  161. @current-change="handleChange"
  162. :page-size="1000"
  163. :total="0" />
  164. `,
  165. methods: {
  166. handleChange(val) {
  167. this.page = val;
  168. }
  169. },
  170. data() {
  171. return { page: 0 };
  172. }
  173. });
  174. const input = vm.$el.querySelector('.el-pagination__jump input');
  175. input.value = 1;
  176. triggerEvent(input, 'change');
  177. expect(vm.page).to.equal(0);
  178. input.value = '我好帅';
  179. triggerEvent(input, 'change');
  180. expect(vm.page).to.equal(0);
  181. });
  182. describe('click pager', () => {
  183. it('click ul', () => {
  184. const vm = createTest(Pagination, {
  185. total: 1000
  186. }, true);
  187. vm.$el.querySelector('.el-pager').click();
  188. expect(vm.internalCurrentPage).to.equal(1);
  189. });
  190. it('click li', () => {
  191. const vm = createTest(Pagination, {
  192. total: 1000
  193. }, true);
  194. vm.$el.querySelectorAll('.el-pager li.number')[1].click();
  195. expect(vm.internalCurrentPage).to.equal(2);
  196. });
  197. it('click next icon-more', () => {
  198. const vm = createTest(Pagination, {
  199. total: 1000
  200. }, true);
  201. vm.$el.querySelector('.el-pager .more').click();
  202. expect(vm.internalCurrentPage).to.equal(6);
  203. });
  204. it('click prev icon-more', done => {
  205. const vm = createTest(Pagination, {
  206. total: 1000
  207. }, true);
  208. vm.$el.querySelector('.btn-quicknext.more').click();
  209. setTimeout(_ => {
  210. expect(vm.$el.querySelector('.btn-quickprev.more')).to.exist;
  211. vm.$el.querySelector('.btn-quickprev.more').click();
  212. expect(vm.internalCurrentPage).to.equal(1);
  213. done();
  214. }, 50);
  215. });
  216. it('click last page', done => {
  217. const vm = createTest(Pagination, {
  218. total: 1000
  219. }, true);
  220. const nodes = vm.$el.querySelectorAll('li.number');
  221. nodes[nodes.length - 1].click();
  222. setTimeout(_ => {
  223. expect(vm.$el.querySelector('.btn-quickprev.more')).to.exist;
  224. expect(vm.$el.querySelector('.btn-quicknext.more')).to.not.exist;
  225. done();
  226. }, 50);
  227. });
  228. });
  229. });