define( [ "jquery", "ui/widgets/checkboxradio" ], function( $ ) { module( "Checkboxradio: core" ); test( "Checkbox - Initial class structure", function( assert ) { expect( 2 ); var input = $( "#check" ), label = $( "label[for=check]" ); input.checkboxradio(); assert.hasClasses( input, "ui-helper-hidden-accessible ui-checkboxradio" ); assert.hasClasses( label, "ui-button ui-widget ui-checkboxradio-label ui-corner-all" ); } ); test( "Radios - Initial class structure", function( assert ) { expect( 6 ); var inputs = $( "#radio0 input" ), labels = $( "#radio0 label" ); inputs.checkboxradio(); inputs.each( function() { assert.hasClasses( this, "ui-helper-hidden-accessible" ); } ); labels.each( function() { assert.hasClasses( this, "ui-button" ); } ); } ); asyncTest( "Ensure checked after single click on checkbox label button", function( assert ) { expect( 2 ); $( "#check2" ).checkboxradio().change( function() { var label = $( this ).checkboxradio( "widget" ); ok( this.checked, "checked ok" ); assert.hasClasses( label, "ui-state-active" ); } ); // Support: Opera // Opera doesn't trigger a change event when this is done synchronously. // This seems to be a side effect of another test, but until that can be // tracked down, this delay will have to do. setTimeout( function() { $( "#check2" ).checkboxradio( "widget" ).simulate( "click" ); start(); } ); } ); test( "Checkbox creation requires a label, and finds it in all cases", function( assert ) { expect( 7 ); var groups = [ "", "", "", "", "", "", "" ]; $.each( groups, function( index, markup ) { var group = $( markup ); group.find( "input[type=checkbox]" ).checkboxradio(); assert.hasClasses( group.find( "label" ), "ui-button" ); } ); } ); test( "Calling checkboxradio on an unsupported element throws an error", function( assert ) { expect( 2 ); var error = new Error( "Can't create checkboxradio on element.nodeName=div and element.type=undefined" ); assert.raises( function() { $( "