1
0
mirror of https://github.com/DataTables/DataTables.git synced 2024-12-01 13:24:10 +01:00
DataTables/media/unit_testing/tests_onhold/5_ajax_objects/asStripClasses.js

133 lines
4.0 KiB
JavaScript

// DATA_TEMPLATE: empty_table
oTest.fnStart( "asStripClasses" );
$(document).ready( function () {
/* Check the default */
$('#example').dataTable( {
"sAjaxSource": "../../../examples/ajax/sources/objects.txt",
"aoColumns": [
{ "mDataSource": "engine" },
{ "mDataSource": "browser" },
{ "mDataSource": "platform" },
{ "mDataSource": "version" },
{ "mDataSource": "grade" }
]
} );
oTest.fnWaitTest(
"Default row striping is applied",
null,
function () {
return $('#example tbody tr:eq(0)').hasClass('odd') &&
$('#example tbody tr:eq(1)').hasClass('even') &&
$('#example tbody tr:eq(2)').hasClass('odd') &&
$('#example tbody tr:eq(3)').hasClass('even');
}
);
oTest.fnWaitTest(
"Row striping on the second page",
function () { $('#example_next').click(); },
function () {
return $('#example tbody tr:eq(0)').hasClass('odd') &&
$('#example tbody tr:eq(1)').hasClass('even') &&
$('#example tbody tr:eq(2)').hasClass('odd') &&
$('#example tbody tr:eq(3)').hasClass('even');
}
);
/* No striping */
oTest.fnWaitTest(
"No row striping",
function () {
oSession.fnRestore();
$('#example').dataTable( {
"sAjaxSource": "../../../examples/ajax/sources/objects.txt",
"aoColumnDefs": [
{ "mDataSource": "engine", "aTargets": [0] },
{ "mDataSource": "browser", "aTargets": [1] },
{ "mDataSource": "platform", "aTargets": [2] },
{ "mDataSource": "version", "aTargets": [3] },
{ "mDataSource": "grade", "aTargets": [4] }
],
"asStripClasses": []
} );
},
function () {
if ( typeof $('#example tbody tr:eq(1)')[0] == 'undefined' )
{
/* Use the 'wait for' to allow this to become true */
return false;
}
return $('#example tbody tr:eq(0)')[0].className == "" &&
$('#example tbody tr:eq(1)')[0].className == "" &&
$('#example tbody tr:eq(2)')[0].className == "" &&
$('#example tbody tr:eq(3)')[0].className == "";
}
);
/* Custom striping */
oTest.fnWaitTest(
"Custom striping [2]",
function () {
oSession.fnRestore();
$('#example').dataTable( {
"sAjaxSource": "../../../examples/ajax/sources/objects.txt",
"aoColumnDefs": [
{ "mDataSource": "engine", "aTargets": [0] },
{ "mDataSource": "browser", "aTargets": [1] },
{ "mDataSource": "platform", "aTargets": [2] },
{ "mDataSource": "version", "aTargets": [3] },
{ "mDataSource": "grade", "aTargets": [4] }
],
"asStripClasses": [ 'test1', 'test2' ]
} );
},
function () {
return $('#example tbody tr:eq(0)').hasClass('test1') &&
$('#example tbody tr:eq(1)').hasClass('test2') &&
$('#example tbody tr:eq(2)').hasClass('test1') &&
$('#example tbody tr:eq(3)').hasClass('test2');
}
);
/* long array of striping */
oTest.fnWaitTest(
"Custom striping [4]",
function () {
oSession.fnRestore();
$('#example').dataTable( {
"sAjaxSource": "../../../examples/ajax/sources/objects.txt",
"aoColumnDefs": [
{ "mDataSource": "engine", "aTargets": [0] },
{ "mDataSource": "browser", "aTargets": [1] },
{ "mDataSource": "platform", "aTargets": [2] },
{ "mDataSource": "version", "aTargets": [3] },
{ "mDataSource": "grade", "aTargets": [4] }
],
"asStripClasses": [ 'test1', 'test2', 'test3', 'test4' ]
} );
},
function () {
return $('#example tbody tr:eq(0)').hasClass('test1') &&
$('#example tbody tr:eq(1)').hasClass('test2') &&
$('#example tbody tr:eq(2)').hasClass('test3') &&
$('#example tbody tr:eq(3)').hasClass('test4');
}
);
oTest.fnWaitTest(
"Custom striping is restarted on second page [2]",
function () { $('#example_next').click(); },
function () {
return $('#example tbody tr:eq(0)').hasClass('test1') &&
$('#example tbody tr:eq(1)').hasClass('test2') &&
$('#example tbody tr:eq(2)').hasClass('test3') &&
$('#example tbody tr:eq(3)').hasClass('test4');
}
);
oTest.fnComplete();
} );