table.spec.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617
  1. import { createVue, triggerEvent, destroyVM } from '../util';
  2. const DELAY = 10;
  3. const testDataArr = [];
  4. const toArray = function(obj) {
  5. return [].slice.call(obj);
  6. };
  7. const getTestData = function() {
  8. return [
  9. { name: 'Toy Story', release: '1995-11-22', director: 'John Lasseter', runtime: 80 },
  10. { name: 'A Bug\'s Life', release: '1998-11-25', director: 'John Lasseter', runtime: 95 },
  11. { name: 'Toy Story 2', release: '1999-11-24', director: 'John Lasseter', runtime: 92 },
  12. { name: 'Monsters, Inc.', release: '2001-11-2', director: 'Peter Docter', runtime: 92 },
  13. { name: 'Finding Nemo', release: '2003-5-30', director: 'Andrew Stanton', runtime: 100 }
  14. ];
  15. };
  16. getTestData().forEach(cur => {
  17. Object.keys(cur).forEach(prop => {
  18. testDataArr.push(cur[prop].toString());
  19. });
  20. });
  21. describe('Table', () => {
  22. describe('rendering data is correct', () => {
  23. const vm = createVue({
  24. template: `
  25. <el-table :data="testData">
  26. <el-table-column prop="name" label="片名" />
  27. <el-table-column prop="release" label="发行日期" />
  28. <el-table-column prop="director" label="导演" />
  29. <el-table-column prop="runtime" label="时长(分)" />
  30. </el-table>
  31. `,
  32. created() {
  33. this.testData = getTestData();
  34. }
  35. });
  36. it('head', done => {
  37. setTimeout(_ => {
  38. const ths = toArray(vm.$el.querySelectorAll('thead th'));
  39. expect(ths.map(node => node.textContent).filter(o => o))
  40. .to.eql(['片名', '发行日期', '导演', '时长(分)']);
  41. done();
  42. }, DELAY);
  43. });
  44. it('row length', () => {
  45. expect(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr')).to.length(getTestData().length);
  46. });
  47. it('row data', () => {
  48. const cells = toArray(vm.$el.querySelectorAll('td .cell'))
  49. .map(node => node.textContent);
  50. expect(cells).to.eql(testDataArr);
  51. destroyVM(vm);
  52. });
  53. });
  54. describe('attributes', () => {
  55. const createTable = function(props, opts) {
  56. return createVue(Object.assign({
  57. template: `
  58. <el-table :data="testData" ${props}>
  59. <el-table-column prop="name" label="片名" />
  60. <el-table-column prop="release" label="发行日期" />
  61. <el-table-column prop="director" label="导演" />
  62. <el-table-column prop="runtime" label="时长(分)" />
  63. </el-table>
  64. `,
  65. created() {
  66. this.testData = getTestData();
  67. }
  68. }, opts));
  69. };
  70. it('height', done => {
  71. const vm = createTable('height="134"');
  72. setTimeout(_ => {
  73. expect(vm.$el.style.height).to.equal('134px');
  74. destroyVM(vm);
  75. done();
  76. }, DELAY);
  77. });
  78. it('stripe', done => {
  79. const vm = createTable('stripe');
  80. setTimeout(_ => {
  81. expect(vm.$el.classList.contains('el-table--striped')).to.true;
  82. destroyVM(vm);
  83. done();
  84. }, DELAY);
  85. });
  86. it('border', done => {
  87. const vm = createTable('border');
  88. setTimeout(_ => {
  89. expect(vm.$el.classList.contains('el-table--border')).to.true;
  90. destroyVM(vm);
  91. done();
  92. }, DELAY);
  93. });
  94. it('fit', done => {
  95. const vm = createTable(':fit="false"');
  96. setTimeout(_ => {
  97. expect(vm.$el.classList.contains('el-table--fit')).to.false;
  98. destroyVM(vm);
  99. done();
  100. }, DELAY);
  101. });
  102. it('tableRowClassName', done => {
  103. const vm = createTable(':row-class-name="tableRowClassName"', {
  104. methods: {
  105. tableRowClassName(row, index) {
  106. if (index === 1) {
  107. return 'info-row';
  108. } else if (index === 3) {
  109. return 'positive-row';
  110. }
  111. return '';
  112. }
  113. }
  114. });
  115. setTimeout(_ => {
  116. expect(vm.$el.querySelectorAll('.info-row')).to.length(1);
  117. expect(vm.$el.querySelectorAll('.positive-row')).to.length(1);
  118. destroyVM(vm);
  119. done();
  120. }, DELAY);
  121. });
  122. // TODO: row-key
  123. });
  124. describe('events', () => {
  125. const createTable = function(prop = '', opts) {
  126. return createVue({
  127. template: `
  128. <el-table :data="testData" @${prop}="handleEvent">
  129. <el-table-column type="selection" />
  130. <el-table-column prop="name" />
  131. <el-table-column prop="release" />
  132. <el-table-column prop="director" />
  133. <el-table-column prop="runtime"/>
  134. </el-table>
  135. `,
  136. methods: {
  137. handleEvent(...args) {
  138. this.result = args;
  139. }
  140. },
  141. created() {
  142. this.testData = getTestData();
  143. },
  144. data() {
  145. return { result: '' };
  146. }
  147. }, true);
  148. };
  149. it('select', done => {
  150. const vm = createTable('select');
  151. setTimeout(_ => {
  152. vm.$el.querySelectorAll('.el-checkbox')[1].click();
  153. expect(vm.result).to.length(2);
  154. expect(vm.result[1]).to.have.property('name').to.equal(getTestData()[0].name);
  155. destroyVM(vm);
  156. done();
  157. }, DELAY);
  158. });
  159. it('select-all', done => {
  160. const vm = createTable('select-all');
  161. setTimeout(_ => {
  162. vm.$el.querySelector('.el-checkbox').click();
  163. setTimeout(_ => {
  164. expect(vm.result).to.length(1);
  165. expect(vm.result[0]).to.length(getTestData().length);
  166. destroyVM(vm);
  167. done();
  168. }, DELAY);
  169. }, DELAY);
  170. });
  171. it('selection-change', done => {
  172. const vm = createTable('selection-change');
  173. setTimeout(_ => {
  174. vm.$el.querySelectorAll('.el-checkbox')[1].click();
  175. expect(vm.result).to.length(1);
  176. destroyVM(vm);
  177. done();
  178. }, DELAY);
  179. });
  180. it('cell-mouse-enter', done => {
  181. const vm = createTable('cell-mouse-enter');
  182. setTimeout(_ => {
  183. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  184. triggerEvent(cell.parentNode, 'mouseenter');
  185. expect(vm.result).to.length(4); // row, column, cell, event
  186. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  187. destroyVM(vm);
  188. done();
  189. }, DELAY);
  190. });
  191. it('cell-mouse-leave', done => {
  192. const vm = createTable('cell-mouse-leave');
  193. setTimeout(_ => {
  194. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[7]; // second row
  195. const cell2 = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  196. triggerEvent(cell2.parentNode, 'mouseenter');
  197. triggerEvent(cell.parentNode, 'mouseleave');
  198. expect(vm.result).to.length(4); // row, column, cell, event
  199. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  200. destroyVM(vm);
  201. done();
  202. }, DELAY);
  203. });
  204. it('cell-click', done => {
  205. const vm = createTable('cell-click');
  206. setTimeout(_ => {
  207. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  208. cell.parentNode.click();
  209. expect(vm.result).to.length(4); // row, column, cell, event
  210. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  211. destroyVM(vm);
  212. done();
  213. }, DELAY);
  214. });
  215. it('row-click', done => {
  216. const vm = createTable('row-click');
  217. setTimeout(_ => {
  218. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  219. triggerEvent(cell.parentNode.parentNode, 'click');
  220. expect(vm.result).to.length(2); // row, event
  221. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  222. destroyVM(vm);
  223. done();
  224. }, DELAY);
  225. });
  226. });
  227. describe('methods', () => {});
  228. describe('column attributes', () => {
  229. const createTable = function(props1, props2, props3, props4, opts, tableProps) {
  230. return createVue(Object.assign({
  231. template: `
  232. <el-table :data="testData" ${tableProps || ''}>
  233. <el-table-column prop="name" ${props1 || ''} />
  234. <el-table-column prop="release" ${props2 || ''} />
  235. <el-table-column prop="director" ${props3 || ''} />
  236. <el-table-column prop="runtime" ${props4 || ''} />
  237. </el-table>
  238. `,
  239. created() {
  240. this.testData = getTestData();
  241. }
  242. }, opts));
  243. };
  244. it('label', done => {
  245. const vm = createTable('label="啊哈哈哈"', 'label="啊啦啦啦"');
  246. setTimeout(_ => {
  247. const ths = toArray(vm.$el.querySelectorAll('thead th'))
  248. .map(node => node.textContent).filter(o => o);
  249. expect(ths).to.eql(['啊哈哈哈', '啊啦啦啦']);
  250. destroyVM(vm);
  251. done();
  252. }, DELAY);
  253. });
  254. it('width', done => {
  255. const vm = createTable('width="123px"', ':width="102"', 'width="39"');
  256. setTimeout(_ => {
  257. const ths = toArray(vm.$el.querySelectorAll('.el-table__header-wrapper colgroup'))
  258. .map(node => node.width).filter(o => o);
  259. expect(ths).to.include('123').include('102').include('39');
  260. destroyVM(vm);
  261. done();
  262. }, DELAY);
  263. });
  264. it('fixed', done => {
  265. const vm = createTable(
  266. 'fixed label="test1"',
  267. 'fixed="right" label="test2"',
  268. 'fixed="left" label="test3"');
  269. setTimeout(_ => {
  270. expect(toArray(vm.$el.querySelectorAll('.el-table__fixed th:not(.hidden)'))
  271. .map(node => node.textContent))
  272. .to.eql(['test1', 'test3']);
  273. expect(toArray(vm.$el.querySelectorAll('.el-table__fixed-right th:not(.hidden)'))
  274. .map(node => node.textContent))
  275. .to.eql(['test2']);
  276. destroyVM(vm);
  277. done();
  278. }, DELAY);
  279. });
  280. // TODO
  281. it('resizable', done => {
  282. const vm = createTable(
  283. 'resizable',
  284. ':resizable="false"',
  285. '',
  286. '',
  287. {},
  288. 'border');
  289. setTimeout(_ => {
  290. const firstCol = vm.$el.querySelector('thead th');
  291. triggerEvent(firstCol, 'mousemove');
  292. triggerEvent(firstCol, 'mousedown');
  293. destroyVM(vm);
  294. done();
  295. }, DELAY);
  296. });
  297. it('formatter', done => {
  298. const vm = createTable(
  299. ':formatter="renderCell"', '', '', '', {
  300. methods: {
  301. renderCell(row, column) {
  302. return `[${row.name}]`;
  303. }
  304. }
  305. });
  306. setTimeout(_ => {
  307. const cells = toArray(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:first-child'));
  308. expect(cells.map(n => n.textContent)).to.eql(getTestData().map(o => `[${o.name}]`));
  309. destroyVM(vm);
  310. done();
  311. }, DELAY);
  312. });
  313. it('show-tooltip-when-overflow', done => {
  314. const vm = createTable('show-tooltip-when-overflow');
  315. setTimeout(_ => {
  316. expect(vm.$el.querySelectorAll('.el-tooltip')).to.length(5);
  317. destroyVM(vm);
  318. done();
  319. }, DELAY);
  320. });
  321. it('inline-template', done => {
  322. const vm = createVue({
  323. template: `
  324. <el-table :data="testData">
  325. <el-table-column prop="name" inline-template>
  326. <span>[{{ row.name }}]</span>
  327. </el-table-column>
  328. <el-table-column prop="release"/>
  329. <el-table-column prop="director"/>
  330. <el-table-column prop="runtime"/>
  331. </el-table>
  332. `,
  333. created() {
  334. this.testData = getTestData();
  335. }
  336. });
  337. setTimeout(_ => {
  338. const cells = toArray(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:first-child'));
  339. expect(cells.map(n => n.textContent)).to.eql(getTestData().map(o => `[${o.name}]`));
  340. destroyVM(vm);
  341. done();
  342. }, DELAY);
  343. });
  344. it('align', done => {
  345. const vm = createTable('align="left"', 'align="right"', 'align="center"');
  346. setTimeout(_ => {
  347. var len = getTestData().length + 1;
  348. expect(vm.$el.querySelectorAll('.is-left')).to.length(len);
  349. expect(vm.$el.querySelectorAll('.is-right')).to.length(len);
  350. expect(vm.$el.querySelectorAll('.is-center')).to.length(len);
  351. destroyVM(vm);
  352. done();
  353. }, DELAY);
  354. });
  355. it('selectable', done => {
  356. const vm = createVue({
  357. template: `
  358. <el-table :data="testData" @selection-change="change">
  359. <el-table-column type="selection" :selectable="filterSelect" />
  360. <el-table-column prop="name" label="name" />
  361. <el-table-column prop="release" label="release" />
  362. <el-table-column prop="director" label="director" />
  363. <el-table-column prop="runtime" label="runtime" />
  364. </el-table>
  365. `,
  366. created() {
  367. this.testData = getTestData();
  368. },
  369. data() {
  370. return { selected: [] };
  371. },
  372. methods: {
  373. change(rows) {
  374. this.selected = rows;
  375. },
  376. filterSelect(row, index) {
  377. return index > 2;
  378. }
  379. }
  380. }, true);
  381. setTimeout(_ => {
  382. vm.$el.querySelector('.el-checkbox').click();
  383. setTimeout(_ => {
  384. expect(vm.selected).to.length(2);
  385. destroyVM(vm);
  386. done();
  387. }, DELAY);
  388. }, DELAY);
  389. });
  390. // TODO
  391. // it('reserve-selection', done => {
  392. // const vm = createVue({
  393. // template: `
  394. // <el-table :data="testData" @selection-change="change">
  395. // <el-table-column type="selection" reserve-selection />
  396. // <el-table-column prop="name" label="片名" />
  397. // <el-table-column prop="release" label="release" />
  398. // <el-table-column prop="director" label="director" />
  399. // <el-table-column prop="runtime" label="runtime" />
  400. // </el-table>
  401. // `,
  402. // created() {
  403. // this.testData = getTestData();
  404. // },
  405. // data() {
  406. // return { selected: [] };
  407. // },
  408. // methods: {
  409. // change(rows) {
  410. // this.selected = rows;
  411. // }
  412. // }
  413. // }, true);
  414. // setTimeout(_ => {
  415. // done();
  416. // }, DELAY);
  417. // });
  418. describe('type', () => {
  419. const createTable = function(type) {
  420. return createVue({
  421. template: `
  422. <el-table :data="testData" @selection-change="change">
  423. <el-table-column type="${type}" />
  424. <el-table-column prop="name" label="name" />
  425. <el-table-column prop="release" label="release" />
  426. <el-table-column prop="director" label="director" />
  427. <el-table-column prop="runtime" label="runtime" />
  428. </el-table>
  429. `,
  430. created() {
  431. this.testData = getTestData();
  432. },
  433. data() {
  434. return { selected: [] };
  435. },
  436. methods: {
  437. change(rows) {
  438. this.selected = rows;
  439. }
  440. }
  441. }, true);
  442. };
  443. describe('= selection', () => {
  444. const vm = createTable('selection');
  445. it('render', done => {
  446. setTimeout(_ => {
  447. expect(vm.$el.querySelectorAll('.el-checkbox')).to.length(getTestData().length + 1);
  448. done();
  449. }, DELAY);
  450. });
  451. it('select all', done => {
  452. vm.$el.querySelector('.el-checkbox').click();
  453. setTimeout(_ => {
  454. expect(vm.selected).to.length(getTestData().length);
  455. done();
  456. }, DELAY);
  457. });
  458. it('cancel all', done => {
  459. vm.$el.querySelector('.el-checkbox').click();
  460. setTimeout(_ => {
  461. expect(vm.selected).to.length(0);
  462. destroyVM(vm);
  463. done();
  464. }, DELAY);
  465. });
  466. it('select one', done => {
  467. const vm2 = createTable('selection');
  468. setTimeout(_ => {
  469. vm2.$el.querySelectorAll('.el-checkbox')[1].click();
  470. setTimeout(_ => {
  471. expect(vm2.selected).to.length(1);
  472. expect(vm2.selected[0].name).to.equal(getTestData()[0].name);
  473. destroyVM(vm2);
  474. done();
  475. }, DELAY);
  476. }, DELAY);
  477. });
  478. });
  479. describe('= index', () => {
  480. const vm = createTable('index');
  481. it('render', done => {
  482. setTimeout(_ => {
  483. expect(toArray(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:first-child'))
  484. .map(node => node.textContent)).to.eql(['1', '2', '3', '4', '5']);
  485. destroyVM(vm);
  486. done();
  487. }, DELAY);
  488. });
  489. });
  490. });
  491. describe('sortable', () => {
  492. const vm = createTable('', '', '', 'sortable');
  493. it('render', done => {
  494. setTimeout(_ => {
  495. expect(vm.$el.querySelectorAll('.caret-wrapper')).to.length(1);
  496. done();
  497. }, DELAY);
  498. });
  499. });
  500. describe('click sortable column', () => {
  501. const vm = createTable('', '', '', 'sortable');
  502. it('ascending', done => {
  503. const elm = vm.$el.querySelector('.caret-wrapper');
  504. elm.click();
  505. setTimeout(_ => {
  506. const lastCells = vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:last-child');
  507. expect(toArray(lastCells).map(node => node.textContent))
  508. .to.eql(['80', '92', '92', '95', '100']);
  509. done();
  510. }, DELAY);
  511. });
  512. it('descending', done => {
  513. const elm = vm.$el.querySelector('.caret-wrapper');
  514. elm.click();
  515. setTimeout(_ => {
  516. const lastCells = vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:last-child');
  517. expect(toArray(lastCells).map(node => node.textContent))
  518. .to.eql(['100', '95', '92', '92', '80']);
  519. destroyVM(vm);
  520. done();
  521. }, DELAY);
  522. });
  523. });
  524. });
  525. });