1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
|
describe('columns.name option', function() {
dt.libs({
js: ['jquery', 'datatables'],
css: ['datatables']
});
describe('Check the defaults', function() {
dt.html('basic');
it('Names are stored in the columns object', function() {
let table = $('#example').DataTable({
columns: [null, { name: 'unit test' }, null, null, null, null]
});
expect($('#example').DataTable.settings[0].aoColumns[1].name).toBe('unit test');
});
dt.html('basic');
it('set names using columns.name and return data of position column', function() {
let table = $('#example').DataTable({
columns: [
{ name: 'name' },
{ name: 'position' },
{ name: 'office' },
{ name: 'age' },
{ name: 'startdate' },
{ name: 'salary' }
]
});
expect(table.column('position:name').data()[0]).toBe('Accountant');
});
dt.html('basic');
it('can have many columns with the same name', function() {
let table = $('#example').DataTable({
columns: [
{ name: 'personal' },
{ name: 'position' },
{ name: 'office' },
{ name: 'personal' },
{ name: 'startdate' },
{ name: 'salary' }
]
});
let personalColumns = table.columns('personal:name')[0];
expect(personalColumns.length).toBe(2);
expect(personalColumns[0]).toBe(0);
expect(personalColumns[1]).toBe(3);
});
dt.html('basic');
it('can set with columnDefs', function() {
let table = $('#example').DataTable({
columnDefs: [{ name: 'personal', targets: [0, 3] }]
});
let personalColumns = table.columns('personal:name')[0];
expect(personalColumns.length).toBe(2);
expect(personalColumns[0]).toBe(0);
expect(personalColumns[1]).toBe(3);
});
});
});
|