(function(win, TableFilter){ // TODO: add sort to test it with different column types var tf = new TableFilter('demo', { base_path: '../dist/tablefilter/', col_types: [ null, null, null, { type: 'formatted-number', decimal: ',', thousands: ','}, 'formatted-number', null, { type: 'date', locale: 'fr', }, { type: 'date', locale: 'en', format: '{dd}-{MM}-{yyyy|yy}' }, { type: 'date', locale: 'en', format: ['{dd}-{months}-{yyyy|yy}'] }, 'IpAddress', { type: 'date', locale: 'en', format: ['{yyyy|yy}-{MM}-{dd} {HH}:{mm}:{ss}'] } ] }); tf.init(); window.tf = tf; module('Sanity checks'); test('Data types', function() { deepEqual(tf instanceof TableFilter, true, 'TableFilter instanciated'); deepEqual( tf.hasType(3, ['formatted-number']) && tf.hasType(4, ['formatted-number']), true, 'Has number column types' ); deepEqual( tf.hasType(6, ['date']) && tf.hasType(7, ['date']) && tf.hasType(8, ['date']), true, 'Has date column types' ); }); module('Data types filtering'); test('Can filter a column with a string', function() { // act tf.setFilterValue(0, 'carl'); tf.filter(); // assert deepEqual(tf.getValidRows(), [14, 18], 'Expected rows'); }); test('Can filter a EU formatted number', function() { // setup tf.clearFilters(); // act tf.setFilterValue(3, '1.836,09'); tf.filter(); // assert deepEqual(tf.getValidRows(), [6], 'Expected rows'); }); test('Can filter a EU formatted number column with a number', function() { // setup tf.clearFilters(); // act tf.setFilterValue(3, 3876); tf.filter(); // assert deepEqual(tf.getValidRows(), [14], 'Expected rows'); }); test('Can filter a EU formatted number column with a number without ' + 'thousands separator', function() { // setup tf.clearFilters(); // act tf.setFilterValue(3, '1393,52'); tf.filter(); // assert deepEqual(tf.getValidRows(), [13], 'Expected rows'); }); test('Can filter a EU formatted number column with a number without ' + 'decimals', function() { // setup tf.clearFilters(); // act tf.setFilterValue(3, '2.805'); tf.filter(); // assert deepEqual(tf.getValidRows(), [7], 'Expected rows'); }); test('Can filter a formatted number', function() { // setup tf.clearFilters(); // act tf.setFilterValue(4, '1,836.09'); tf.filter(); // assert deepEqual(tf.getValidRows(), [6], 'Expected rows'); }); test('Can filter a number', function() { // setup tf.clearFilters(); // act tf.setFilterValue(4, 1836.09); tf.filter(); // assert deepEqual(tf.getValidRows(), [6], 'Expected rows'); }); test('Can filter a formatted number column with a number', function() { // setup tf.clearFilters(); // act tf.setFilterValue(4, 3876); tf.filter(); // assert deepEqual(tf.getValidRows(), [14], 'Expected rows'); }); test('Can filter a formatted number column with a number without ' + 'thousands separator', function() { // setup tf.clearFilters(); // act tf.setFilterValue(4, '1393.52'); tf.filter(); // assert deepEqual(tf.getValidRows(), [13], 'Expected rows'); }); test('Can filter a formatted number column with a number without ' + 'decimals', function() { // setup tf.clearFilters(); // act tf.setFilterValue(4, '2,805'); tf.filter(); // assert deepEqual(tf.getValidRows(), [7], 'Expected rows'); }); test('Can filter a EU formatted date column', function() { // setup tf.clearFilters(); // act tf.setFilterValue(6, '14/7/1994'); tf.filter(); // assert deepEqual(tf.getValidRows(), [16], 'Expected rows'); }); test('Can filter a EU formatted date column with different date separator', function() { // setup tf.clearFilters(); // act tf.setFilterValue(6, '20-10-97'); tf.filter(); // assert deepEqual(tf.getValidRows(), [17], 'Expected rows'); }); test('Can filter a formatted date column', function() { // setup tf.clearFilters(); // act tf.setFilterValue(7, '7/14/1994'); tf.filter(); // assert deepEqual(tf.getValidRows(), [16], 'Expected rows'); }); test('Can filter a formatted date column with different date separator', function() { // setup tf.clearFilters(); // act tf.setFilterValue(7, '10-20-97'); tf.filter(); // assert deepEqual(tf.getValidRows(), [17], 'Expected rows'); }); test('Can filter a dd-MMM-yyy formatted date column', function() { // setup tf.clearFilters(); // act tf.setFilterValue(8, '3-Jul-2002'); tf.filter(); // assert deepEqual(tf.getValidRows(), [8], 'Expected rows'); }); test('Can filter a dd-MMM-yyy formatted date column with different date ' + 'separator', function() { // setup tf.clearFilters(); // act tf.setFilterValue(8, '25.Mar.2000'); tf.filter(); // assert deepEqual(tf.getValidRows(), [4], 'Expected rows'); }); test('Can filter an IP address column', function() { // setup tf.clearFilters(); // act tf.setFilterValue(9, '219.115.156.145'); tf.filter(); // assert deepEqual(tf.getValidRows(), [8], 'Expected rows'); }); test('Can filter an IP address column with a truncated IP address', function() { // setup tf.clearFilters(); // act tf.setFilterValue(9, '219.115.15'); tf.filter(); // assert deepEqual(tf.getValidRows(), [4, 8, 14], 'Expected rows'); }); test('Can filter datetime format', function() { // setup tf.clearFilters(); // act tf.setFilterValue(10, '2006-06-03 11:59:48'); tf.filter(); // assert deepEqual(tf.getValidRows(), [8], 'Expected rows'); }); test('Can filter datetime format with operator', function() { // setup tf.clearFilters(); // act tf.setFilterValue(10, '>2006-06-03 11:59:48'); tf.filter(); // assert deepEqual(tf.getValidRows().length, 8, 'Expected rows'); }); module('Locale helpers'); test('Can get decimal separator for given column from config', function() { // act var result = tf.getDecimal(3); // assert deepEqual(result, ',', 'Decimal separator for given column'); }); test('Can get decimal separator for given column from global setting', function() { // act var result = tf.getDecimal(1); // assert deepEqual(result, '.', 'Decimal separator for given column'); }); module('Tear-down'); test('can destroy TableFilter DOM elements', function() { tf.destroy(); deepEqual(tf.isInitialized(), false, 'Filters removed'); }); })(window, TableFilter);