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 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
|
// todo tests
// - Confirm it exists and is a function
// - Confirm it returns an API instance
// - Even if only a single column is selected
// - Create a table which uses the following for various columns (you might need to create multiple tables)
// - Integer (array based tables)
// - Function
// - String (object based tables)
// - Select multiple columns and confirm that the data source for each selected column is:
// - e.g. if `columns.data` is not set it should return an integer (array based tables)
// - if `columns.data` is a string it should return that string
// - if `columns.data` is a function it should return that function, etc
var dataSet = [
[ 2016, 37],
[ 2016, 27],
[ 2016, 23],
[ 2016, 19],
[ 2016, 43],
[ 2016, 76],
];
describe( "columns- columns().dataSrc()", function() {
dt.libs( {
js: [ 'jquery', 'datatables' ],
css: [ 'datatables' ]
} );
describe("Check the defaults", function () {
dt.html( 'basic' );
it("Exists and is a function", function () {
var table = $('#example').DataTable();
expect(typeof table.columns().dataSrc).toBe('function');
});
dt.html( 'basic' );
it("Returns an API instance", function () {
var table = $('#example').DataTable();
expect(table.columns().dataSrc() instanceof $.fn.dataTable.Api).toBe(true);
});
dt.html( 'basic' );
it("Returns an API instance- 1 column selected", function () {
var table = $('#example').DataTable();
expect(table.columns(1).dataSrc() instanceof $.fn.dataTable.Api).toBe(true);
});
dt.html( 'currency' );
it("If columns.data is not set it should return an integer (array based table)", function () {
var table = $('#example').DataTable({
data: dataSet,
columns: [
{title: "Name"},
{title: "Age"}
]
});
var result = table.columns().dataSrc();
expect(typeof result[0]).toBe('number');
});
dt.html( 'currency');
it("Returns a function, when using a function set in columnDefs.data", function () {
var count = 0;
var table = $('#example').DataTable({
"data": dataSet,
"columnDefs": [ {
"targets": 1,
"data": function (row, type, val, meta){
count = val + count;
return count;
}
}]
});
var result = table.columns(1).dataSrc();
expect(typeof result[0]).toBe('function');
});
dt.html( 'empty' );
it("Returns string when using string in column (object based table)", function (done) {
var table = $('#example').DataTable({
"ajax": '/base/test/data/data.txt',
columns: [
{ data: "name" },
{ data: "position" },
{ data: "office" },
{ data: "extn" },
{ data: "start_date" },
{ data: "salary" }
],
initComplete: function ( settings, json ) {
var result = table.columns(1).dataSrc();
expect(typeof result[0]).toBe('string');
done();
}
});
});
});
});
|