define( [ "qunit", "jquery", "lib/helper", "ui/widgets/selectmenu" ], function( QUnit, $, helper ) { QUnit.module( "selectmenu: options", { afterEach: helper.moduleAfterEach } ); QUnit.test( "appendTo: null", function( assert ) { assert.expect( 1 ); var element = $( "#speed" ).selectmenu(); assert.equal( element.selectmenu( "menuWidget" ).parent().parent()[ 0 ], document.body, "defaults to body" ); } ); QUnit.test( "appendTo: explicit", function( assert ) { assert.expect( 6 ); var detached = $( "
" ), element = $( "#speed" ); element.selectmenu( { appendTo: ".selectmenu-wrap" } ); assert.equal( element.selectmenu( "menuWidget" ).parent().parent()[ 0 ], $( "#selectmenu-wrap1" )[ 0 ], "first found element" ); assert.equal( $( "#selectmenu-wrap2 .ui-selectmenu" ).length, 0, "only appends to one element" ); element.selectmenu( "destroy" ); element.selectmenu().selectmenu( "option", "appendTo", "#selectmenu-wrap1" ); assert.equal( element.selectmenu( "menuWidget" ).parent().parent()[ 0 ], $( "#selectmenu-wrap1" )[ 0 ], "modified after init" ); element.selectmenu( "destroy" ); element.selectmenu( { appendTo: detached } ); assert.equal( element.selectmenu( "menuWidget" ).parent().parent()[ 0 ], detached[ 0 ], "detached jQuery object" ); element.selectmenu( "destroy" ); element.selectmenu( { appendTo: detached[ 0 ] } ); assert.equal( element.selectmenu( "menuWidget" ).parent().parent()[ 0 ], detached[ 0 ], "detached DOM element" ); element.selectmenu( "destroy" ); element.selectmenu().selectmenu( "option", "appendTo", detached ); assert.equal( element.selectmenu( "menuWidget" ).parent().parent()[ 0 ], detached[ 0 ], "detached DOM element via option()" ); element.selectmenu( "destroy" ); } ); QUnit.test( "appendTo: ui-front", function( assert ) { assert.expect( 2 ); var element = $( "#speed" ); $( "#selectmenu-wrap2" ).addClass( "ui-front" ); element.selectmenu(); assert.equal( element.selectmenu( "menuWidget" ).parent().parent()[ 0 ], $( "#selectmenu-wrap2" )[ 0 ], "null, inside .ui-front" ); element.selectmenu( "destroy" ); element.selectmenu( { appendTo: $() } ); assert.equal( element.selectmenu( "menuWidget" ).parent().parent()[ 0 ], $( "#selectmenu-wrap2" )[ 0 ], "empty jQuery object, inside .ui-front" ); } ); QUnit.test( "CSS styles", function( assert ) { assert.expect( 5 ); var element = $( "#speed" ).selectmenu(), button = element.selectmenu( "widget" ), menu = element.selectmenu( "menuWidget" ); element.selectmenu( "open" ); assert.hasClasses( button, "ui-corner-top" ); assert.lacksClasses( button, "ui-corner-all" ); assert.hasClasses( button.find( "span.ui-icon" ), "ui-icon-triangle-1-s" ); assert.hasClasses( menu, "ui-corner-bottom" ); assert.lacksClasses( button, "ui-corner-all" ); } ); QUnit.test( "width", function( assert ) { assert.expect( 6 ); var button, element = $( "#speed" ); element.selectmenu(); button = element.selectmenu( "widget" ); assert.equal( button[ 0 ].style.width, "", "no inline style" ); element.selectmenu( "option", "width", null ); assert.equal( button.outerWidth(), element.outerWidth(), "button width auto" ); element.outerWidth( 100 ); element.selectmenu( "refresh" ); assert.equal( button.outerWidth(), 100, "button width set by CSS" ); element .width( "" ) .selectmenu( "option", "width", 100 ) .selectmenu( "refresh" ); assert.equal( button.outerWidth(), 100, "button width set by JS option" ); element .append( $( "