numericValidator.spec.js 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. describe('numericValidator', () => {
  2. var id = 'testContainer';
  3. beforeEach(function() {
  4. this.$container = $(`<div id="${id}"></div>`).appendTo('body');
  5. });
  6. afterEach(function() {
  7. if (this.$container) {
  8. destroy();
  9. this.$container.remove();
  10. }
  11. });
  12. var arrayOfObjects = function() {
  13. return [
  14. {id: 1, name: 'Ted', lastName: 'Right'},
  15. {id: 2, name: 'Frank', lastName: 'Honest'},
  16. {id: 3, name: 'Joan', lastName: 'Well'},
  17. {id: 4, name: 'Sid', lastName: 'Strong'},
  18. {id: 5, name: 'Jane', lastName: 'Neat'},
  19. {id: 6, name: 'Chuck', lastName: 'Jackson'},
  20. {id: 7, name: 'Meg', lastName: 'Jansen'},
  21. {id: 8, name: 'Rob', lastName: 'Norris'},
  22. {id: 9, name: 'Sean', lastName: 'O\'Hara'},
  23. {id: 10, name: 'Eve', lastName: 'Branson'}
  24. ];
  25. };
  26. it('should validate an empty string (default behavior)', (done) => {
  27. var onAfterValidate = jasmine.createSpy('onAfterValidate');
  28. handsontable({
  29. data: arrayOfObjects(),
  30. columns: [
  31. {data: 'id', type: 'numeric'},
  32. {data: 'name'},
  33. {data: 'lastName'}
  34. ],
  35. afterValidate: onAfterValidate
  36. });
  37. setDataAtCell(2, 0, '');
  38. setTimeout(() => {
  39. expect(onAfterValidate).toHaveBeenCalledWith(true, '', 2, 'id', undefined, undefined);
  40. done();
  41. }, 100);
  42. });
  43. it('should not validate non numeric string', (done) => {
  44. var onAfterValidate = jasmine.createSpy('onAfterValidate');
  45. handsontable({
  46. data: arrayOfObjects(),
  47. columns: [
  48. {data: 'id', type: 'numeric'},
  49. {data: 'name'},
  50. {data: 'lastName'}
  51. ],
  52. afterValidate: onAfterValidate
  53. });
  54. setDataAtCell(2, 0, 'test');
  55. setTimeout(() => {
  56. expect(onAfterValidate).toHaveBeenCalledWith(false, 'test', 2, 'id', undefined, undefined);
  57. done();
  58. }, 100);
  59. });
  60. it('should validate numeric string', (done) => {
  61. var onAfterValidate = jasmine.createSpy('onAfterValidate');
  62. handsontable({
  63. data: arrayOfObjects(),
  64. columns: [
  65. {data: 'id', type: 'numeric'},
  66. {data: 'name'},
  67. {data: 'lastName'}
  68. ],
  69. afterValidate: onAfterValidate
  70. });
  71. setDataAtCell(2, 0, '123');
  72. setTimeout(() => {
  73. expect(onAfterValidate).toHaveBeenCalledWith(true, 123, 2, 'id', undefined, undefined);
  74. done();
  75. }, 100);
  76. });
  77. it('should validate signed numeric string', (done) => {
  78. var onAfterValidate = jasmine.createSpy('onAfterValidate');
  79. handsontable({
  80. data: arrayOfObjects(),
  81. columns: [
  82. {data: 'id', type: 'numeric'},
  83. {data: 'name'},
  84. {data: 'lastName'}
  85. ],
  86. afterValidate: onAfterValidate
  87. });
  88. setDataAtCell(2, 0, '-123');
  89. setTimeout(() => {
  90. expect(onAfterValidate).toHaveBeenCalledWith(true, -123, 2, 'id', undefined, undefined);
  91. done();
  92. }, 100);
  93. });
  94. describe('allowEmpty', () => {
  95. it('should not validate an empty string when allowEmpty is set as `false`', (done) => {
  96. var onAfterValidate = jasmine.createSpy('onAfterValidate');
  97. handsontable({
  98. data: arrayOfObjects(),
  99. columns: [
  100. {data: 'id', type: 'numeric', allowEmpty: false},
  101. {data: 'name'},
  102. {data: 'lastName'}
  103. ],
  104. afterValidate: onAfterValidate
  105. });
  106. setDataAtCell(2, 0, '');
  107. setTimeout(() => {
  108. expect(onAfterValidate).toHaveBeenCalledWith(false, '', 2, 'id', undefined, undefined);
  109. done();
  110. }, 100);
  111. });
  112. it('should not validate `null` when allowEmpty is set as `false`', (done) => {
  113. var onAfterValidate = jasmine.createSpy('onAfterValidate');
  114. handsontable({
  115. data: arrayOfObjects(),
  116. columns: [
  117. {data: 'id', type: 'numeric', allowEmpty: false},
  118. {data: 'name'},
  119. {data: 'lastName'}
  120. ],
  121. afterValidate: onAfterValidate
  122. });
  123. setDataAtCell(2, 0, null);
  124. setTimeout(() => {
  125. expect(onAfterValidate).toHaveBeenCalledWith(false, null, 2, 'id', undefined, undefined);
  126. done();
  127. }, 100);
  128. });
  129. it('should not validate `undefined` when allowEmpty is set as `false`', (done) => {
  130. var onAfterValidate = jasmine.createSpy('onAfterValidate');
  131. handsontable({
  132. data: arrayOfObjects(),
  133. columns: [
  134. {data: 'id', type: 'numeric', allowEmpty: false},
  135. {data: 'name'},
  136. {data: 'lastName'}
  137. ],
  138. afterValidate: onAfterValidate
  139. });
  140. setDataAtCell(2, 0, void 0);
  141. setTimeout(() => {
  142. expect(onAfterValidate).toHaveBeenCalledWith(false, void 0, 2, 'id', undefined, undefined);
  143. done();
  144. }, 100);
  145. });
  146. it('should validate 0 when allowEmpty is set as `false`', (done) => {
  147. var onAfterValidate = jasmine.createSpy('onAfterValidate');
  148. handsontable({
  149. data: arrayOfObjects(),
  150. columns: [
  151. {data: 'id', type: 'numeric', allowEmpty: false},
  152. {data: 'name'},
  153. {data: 'lastName'}
  154. ],
  155. afterValidate: onAfterValidate
  156. });
  157. setDataAtCell(2, 0, 0);
  158. setTimeout(() => {
  159. expect(onAfterValidate).toHaveBeenCalledWith(true, 0, 2, 'id', undefined, undefined);
  160. done();
  161. }, 100);
  162. });
  163. it('should add / remove `htInvalid` class properly when validating non-numeric data', (done) => {
  164. var hot = handsontable({
  165. data: [
  166. {id: 1, name: 'Ted', salary: 10000},
  167. {id: 2, name: 'Frank', salary: '5300'},
  168. {id: 3, name: 'Joan', salary: 'non-numeric value'}
  169. ],
  170. columns: [
  171. {data: 'id'},
  172. {data: 'name'},
  173. {data: 'salary', type: 'numeric', allowInvalid: false}
  174. ]
  175. });
  176. hot.validateCells();
  177. setTimeout(() => {
  178. expect($(getCell(1, 2)).hasClass(hot.getSettings().invalidCellClassName)).toBe(false);
  179. expect($(getCell(2, 2)).hasClass(hot.getSettings().invalidCellClassName)).toBe(true);
  180. setDataAtCell(2, 2, 8000);
  181. }, 200);
  182. setTimeout(() => {
  183. expect($(getCell(2, 2)).hasClass(hot.getSettings().invalidCellClassName)).toBe(false);
  184. done();
  185. }, 400);
  186. });
  187. });
  188. });