2017-12-20 05:33:33 -06:00
|
|
|
import TableModel from 'app/core/table_model';
|
2015-11-09 10:58:02 -06:00
|
|
|
|
2017-12-20 05:33:33 -06:00
|
|
|
describe('when sorting table desc', () => {
|
2018-08-26 14:52:57 -05:00
|
|
|
let table;
|
|
|
|
const panel = {
|
2017-12-20 05:33:33 -06:00
|
|
|
sort: { col: 0, desc: true },
|
2015-11-09 10:58:02 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
table = new TableModel();
|
|
|
|
table.columns = [{}, {}];
|
|
|
|
table.rows = [[100, 12], [105, 10], [103, 11]];
|
|
|
|
table.sort(panel.sort);
|
|
|
|
});
|
|
|
|
|
2017-12-20 05:33:33 -06:00
|
|
|
it('should sort by time', () => {
|
2017-10-22 00:03:26 -05:00
|
|
|
expect(table.rows[0][0]).toBe(105);
|
|
|
|
expect(table.rows[1][0]).toBe(103);
|
|
|
|
expect(table.rows[2][0]).toBe(100);
|
2015-11-09 10:58:02 -06:00
|
|
|
});
|
|
|
|
|
2017-12-20 05:33:33 -06:00
|
|
|
it('should mark column being sorted', () => {
|
2017-10-22 00:03:26 -05:00
|
|
|
expect(table.columns[0].sort).toBe(true);
|
|
|
|
expect(table.columns[0].desc).toBe(true);
|
2015-11-09 10:58:02 -06:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2017-12-20 05:33:33 -06:00
|
|
|
describe('when sorting table asc', () => {
|
2015-11-09 10:58:02 -06:00
|
|
|
var table;
|
2018-08-26 14:52:57 -05:00
|
|
|
const panel = {
|
2017-12-20 05:33:33 -06:00
|
|
|
sort: { col: 1, desc: false },
|
2015-11-09 10:58:02 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
table = new TableModel();
|
|
|
|
table.columns = [{}, {}];
|
|
|
|
table.rows = [[100, 11], [105, 15], [103, 10]];
|
|
|
|
table.sort(panel.sort);
|
|
|
|
});
|
|
|
|
|
2017-12-20 05:33:33 -06:00
|
|
|
it('should sort by time', () => {
|
2017-10-22 00:03:26 -05:00
|
|
|
expect(table.rows[0][1]).toBe(10);
|
|
|
|
expect(table.rows[1][1]).toBe(11);
|
|
|
|
expect(table.rows[2][1]).toBe(15);
|
2015-11-09 10:58:02 -06:00
|
|
|
});
|
|
|
|
});
|
2018-07-02 13:14:41 -05:00
|
|
|
|
|
|
|
describe('when sorting with nulls', () => {
|
|
|
|
var table;
|
|
|
|
var values;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
table = new TableModel();
|
|
|
|
table.columns = [{}, {}];
|
|
|
|
table.rows = [[42, ''], [19, 'a'], [null, 'b'], [0, 'd'], [null, null], [2, 'c'], [0, null], [-8, '']];
|
|
|
|
});
|
|
|
|
|
|
|
|
it('numbers with nulls at end with asc sort', () => {
|
|
|
|
table.sort({ col: 0, desc: false });
|
|
|
|
values = table.rows.map(row => row[0]);
|
|
|
|
expect(values).toEqual([-8, 0, 0, 2, 19, 42, null, null]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('numbers with nulls at start with desc sort', () => {
|
|
|
|
table.sort({ col: 0, desc: true });
|
|
|
|
values = table.rows.map(row => row[0]);
|
|
|
|
expect(values).toEqual([null, null, 42, 19, 2, 0, 0, -8]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('strings with nulls at end with asc sort', () => {
|
|
|
|
table.sort({ col: 1, desc: false });
|
|
|
|
values = table.rows.map(row => row[1]);
|
|
|
|
expect(values).toEqual(['', '', 'a', 'b', 'c', 'd', null, null]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('strings with nulls at start with desc sort', () => {
|
|
|
|
table.sort({ col: 1, desc: true });
|
|
|
|
values = table.rows.map(row => row[1]);
|
|
|
|
expect(values).toEqual([null, null, 'd', 'c', 'b', 'a', '', '']);
|
|
|
|
});
|
|
|
|
});
|