mirror of
https://github.com/apache/superset.git
synced 2026-04-09 11:25:23 +00:00
* Migrate Chord, Calendar * Migrate CountryMap * Add display name and rename Chord.jsx to Chord.js * migrate Histogram * add force-directed * migrate Heatmap * add horizon * migrate parallel coordinates * migrate partition * migrate pivot table * migrate rose * remove react-dom * migrate Sankey * migrate sunburst * migrate table * migrate treemap * migrate filterbox * migrate wordcloud * add paired t-test * fix unit test * remove renaming * rename fields
102 lines
2.9 KiB
JavaScript
102 lines
2.9 KiB
JavaScript
import { expect } from 'chai';
|
|
import $ from 'jquery';
|
|
import '../../helpers/shim';
|
|
import tableVis from '../../../src/visualizations/Table/adaptor';
|
|
|
|
describe('table viz', () => {
|
|
const div = '<div id="slice-container"><div class="dataTables_wrapper"></div></div>';
|
|
const baseSlice = {
|
|
selector: '#slice-container',
|
|
formData: {
|
|
metrics: ['count'],
|
|
timeseries_limit_metric: null,
|
|
},
|
|
datasource: {
|
|
verbose_map: {},
|
|
},
|
|
getFilters: () => ({}),
|
|
removeFilter() {},
|
|
addFilter() {},
|
|
width: () => 0,
|
|
height: () => 0,
|
|
};
|
|
const basePayload = {
|
|
data: {
|
|
records: [
|
|
{ gender: 'boy', count: 39245 },
|
|
{ gender: 'girl', count: 36446 },
|
|
],
|
|
columns: ['gender', 'count'],
|
|
},
|
|
};
|
|
|
|
it('renders into a container', () => {
|
|
$('body').html(div);
|
|
const container = $(baseSlice.selector);
|
|
expect(container.length).to.equal(1);
|
|
});
|
|
|
|
it('renders header and body datatables in container', () => {
|
|
$('body').html(div);
|
|
const container = $(baseSlice.selector);
|
|
|
|
expect(container.find('.dataTable').length).to.equal(0);
|
|
tableVis(baseSlice, basePayload);
|
|
expect(container.find('.dataTable').length).to.equal(2);
|
|
|
|
const tableHeader = container.find('.dataTable')[0];
|
|
expect($(tableHeader).find('thead tr').length).to.equal(1);
|
|
expect($(tableHeader).find('th').length).to.equal(2);
|
|
|
|
const tableBody = container.find('.dataTable')[1];
|
|
expect($(tableBody).find('tbody tr').length).to.equal(2);
|
|
expect($(tableBody).find('th').length).to.equal(2);
|
|
});
|
|
|
|
it('hides the sort by column', () => {
|
|
$('body').html(div);
|
|
const slice = { ...baseSlice };
|
|
slice.formData = { ...baseSlice.formData,
|
|
timeseries_limit_metric: {
|
|
label: 'SUM(sum_boys)',
|
|
},
|
|
};
|
|
const payload = {
|
|
data: {
|
|
records: [
|
|
{ gender: 'boy', count: 39245, 'SUM(sum_boys)': 48133355 },
|
|
{ gender: 'girl', count: 36446, 'SUM(sum_boys)': 0 },
|
|
],
|
|
columns: ['gender', 'count', 'SUM(sum_boys)'],
|
|
},
|
|
};
|
|
tableVis(slice, payload);
|
|
|
|
const container = $(slice.selector);
|
|
const tableHeader = container.find('.dataTable')[0];
|
|
expect($(tableHeader).find('th').length).to.equal(2);
|
|
});
|
|
|
|
it('works with empty list for sort by', () => {
|
|
$('body').html(div);
|
|
const slice = { ...baseSlice };
|
|
slice.formData = { ...baseSlice.formData,
|
|
timeseries_limit_metric: [],
|
|
};
|
|
const payload = {
|
|
data: {
|
|
records: [
|
|
{ gender: 'boy', count: 39245, 'SUM(sum_boys)': 48133355 },
|
|
{ gender: 'girl', count: 36446, 'SUM(sum_boys)': 0 },
|
|
],
|
|
columns: ['gender', 'count', 'SUM(sum_boys)'],
|
|
},
|
|
};
|
|
tableVis(slice, payload);
|
|
|
|
const container = $(slice.selector);
|
|
const tableBody = container.find('.dataTable')[1];
|
|
expect($(tableBody).find('th').length).to.equal(3);
|
|
});
|
|
});
|