Skip to content
Closed
10 changes: 10 additions & 0 deletions tests/unit/accordion/accordion_common.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,16 @@ TestHelpers.commonWidgetTests( "accordion", {
defaults: {
active: 0,
animate: {},
classes: {
"ui-accordion": null,
"ui-accordion-header": "ui-corner-top",
"ui-accordion-header-active": null,
"ui-accordion-header-collapsed": "ui-corner-all",
"ui-accordion-content": "ui-corner-bottom",
"ui-accordion-content-active": null,
"ui-accordion-header-icon": null,
"ui-accordion-icons": null
},
collapsible: false,
disabled: false,
event: "click",
Expand Down
22 changes: 16 additions & 6 deletions tests/unit/accordion/accordion_core.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,25 @@ module( "accordion: core", setupTeardown() );

$.each( { div: "#list1", ul: "#navigation", dl: "#accordion-dl" }, function( type, selector ) {
test( "markup structure: " + type, function() {
expect( 4 );
var element = $( selector ).accordion();
expect( 11 );
var element = $( selector ).accordion(),
headers = element.find( ".ui-accordion-header" ),
panels = element.find( ".ui-accordion-content" );

ok( element.hasClass( "ui-accordion" ), "main element is .ui-accordion" );
equal( element.find( ".ui-accordion-header" ).length, 3,
ok( element.hasClass( "ui-widget" ), "main element is .ui-widget" );
ok( headers.hasClass( "ui-corner-top" ), "header is .ui-corner-top" );
ok( !headers.eq( 0 ).hasClass( "ui-corner-all" ), "open header is not .ui-corner-all" );
ok( headers.eq( 1 ).hasClass( "ui-corner-all" ), "closed header is .ui-corner-all" );
ok( headers.next().hasClass( "ui-accordion-content" ), "panel is .ui-accordion-content" );
ok( headers.next().hasClass( "ui-widget-content" ), "panel is .ui-widget-content" );
ok( headers.next().hasClass( "ui-corner-bottom" ), "panel is .ui-corner-bottom" );

equal( headers.length, 3,
".ui-accordion-header elements exist, correct number" );
equal( element.find( ".ui-accordion-content" ).length, 3,
equal( panels.length, 3,
".ui-accordion-content elements exist, correct number" );
deepEqual( element.find( ".ui-accordion-header" ).next().get(),
element.find( ".ui-accordion-content" ).get(),
deepEqual( headers.next().get(), panels.get(),
"content panels come immediately after headers" );
});
});
Expand Down
8 changes: 7 additions & 1 deletion tests/unit/accordion/accordion_methods.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,16 @@ var equalHeight = TestHelpers.accordion.equalHeight,
module( "accordion: methods", setupTeardown() );

test( "destroy", function() {
expect( 1 );
expect( 2 );
domEqual( "#list1", function() {
$( "#list1" ).accordion().accordion( "destroy" );
});
// Animate
domEqual( "#list1", function() {
$( "#list1" ).accordion()
.accordion( "option", "active", 1 )
.accordion( "destroy" );
});
});

test( "enable/disable", function() {
Expand Down
5 changes: 5 additions & 0 deletions tests/unit/autocomplete/autocomplete_common.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,11 @@ TestHelpers.commonWidgetTests( "autocomplete", {
defaults: {
appendTo: null,
autoFocus: false,
classes: {
"ui-autocomplete": null,
"ui-autocomplete-input": null,
"ui-autocomplete-loading": null
},
delay: 300,
disabled: false,
messages: {
Expand Down
9 changes: 9 additions & 0 deletions tests/unit/autocomplete/autocomplete_core.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,15 @@

module( "autocomplete: core" );

test( "markup structure", function() {
expect( 2 );
var element = $( "#autocomplete" ).autocomplete(),
menu = element.autocomplete( "widget" );

ok( element.hasClass( "ui-autocomplete-input" ), "main element is .ui-autocomplete-input" );
ok( menu.hasClass( "ui-autocomplete" ), "menu is .ui-autocomplete" );
});

test( "prevent form submit on enter when menu is active", function() {
expect( 2 );
var event,
Expand Down
10 changes: 10 additions & 0 deletions tests/unit/button/button_common.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,15 @@
TestHelpers.commonWidgetTests( "button", {
defaults: {
classes: {
"ui-button": "ui-corner-all",
"ui-button-text": null,
"ui-button-icons-only": null,
"ui-button-icon-only": null,
"ui-button-text-icons": null,
"ui-button-text-icon-primary": null,
"ui-button-text-icon-secondary": null,
"ui-button-text-only": null
},
disabled: null,
icons: {
primary: null,
Expand Down
6 changes: 4 additions & 2 deletions tests/unit/button/button_core.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,25 +8,27 @@
module("button: core");

test("checkbox", function() {
expect( 4 );
expect( 5 );
var input = $("#check"),
label = $("label[for=check]");
ok( input.is(":visible") );
ok( label.is(":not(.ui-button)") );
input.button();
ok( input.is(".ui-helper-hidden-accessible") );
ok( label.is(".ui-button") );
ok( label.is(".ui-corner-all") );
});

test("radios", function() {
expect( 4 );
expect( 5 );
var inputs = $("#radio0 input"),
labels = $("#radio0 label");
ok( inputs.is(":visible") );
ok( labels.is(":not(.ui-button)") );
inputs.button();
ok( inputs.is(".ui-helper-hidden-accessible") );
ok( labels.is(".ui-button") );
ok( labels.is(".ui-corner-all") );
});

function assert(noForm, form1, form2) {
Expand Down
14 changes: 13 additions & 1 deletion tests/unit/dialog/dialog_common.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,22 @@ TestHelpers.commonWidgetTests( "dialog", {
appendTo: "body",
autoOpen: true,
buttons: [],
classes: {
"ui-dialog": "ui-corner-all",
"ui-dialog-content": null,
"ui-dialog-titlebar": "ui-corner-all",
"ui-dialog-titlebar-close": null,
"ui-dialog-title": null,
"ui-dialog-buttons": null,
"ui-dialog-buttonpane": null,
"ui-dialog-buttonset": null,
"ui-dialog-dragging": null,
"ui-dialog-resizing": null,
"ui-widget-overlay": null
},
closeOnEscape: true,
closeText: "Close",
disabled: false,
dialogClass: "",
draggable: true,
height: "auto",
hide: null,
Expand Down
56 changes: 56 additions & 0 deletions tests/unit/dialog/dialog_common_deprecated.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
TestHelpers.commonWidgetTests( "dialog", {
defaults: {
appendTo: "body",
autoOpen: true,
buttons: [],
classes: {
"ui-dialog": "ui-corner-all",
"ui-dialog-content": null,
"ui-dialog-titlebar": "ui-corner-all",
"ui-dialog-titlebar-close": null,
"ui-dialog-title": null,
"ui-dialog-buttons": null,
"ui-dialog-buttonpane": null,
"ui-dialog-buttonset": null,
"ui-dialog-dragging": null,
"ui-dialog-resizing": null,
"ui-widget-overlay": null
},
closeOnEscape: true,
closeText: "close",
dialogClass: "",
disabled: false,
draggable: true,
height: "auto",
hide: null,
maxHeight: null,
maxWidth: null,
minHeight: 150,
minWidth: 150,
modal: false,
position: {
my: "center",
at: "center",
of: window,
collision: "fit",
using: $.ui.dialog.prototype.options.position.using
},
resizable: true,
show: null,
title: null,
width: 300,

// callbacks
beforeClose: null,
close: null,
create: null,
drag: null,
dragStart: null,
dragStop: null,
focus: null,
open: null,
resize: null,
resizeStart: null,
resizeStop: null
}
});
35 changes: 35 additions & 0 deletions tests/unit/dialog/dialog_core.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,41 @@
// TODO add teardown callback to remove dialogs
module("dialog: core");

test( "markup structure", function() {
expect( 15 );
var element = $("<div></div>").dialog({
buttons: [{
text: "Ok",
click: $.noop
}]
}),
widget = element.dialog( "widget" ),
titlebar = widget.find( ".ui-dialog-titlebar" ),
close = titlebar.find( "button" ),
buttonpane = widget.find( ".ui-dialog-buttonpane" );

ok( widget.hasClass( "ui-dialog" ), "widget is .ui-dialog" );
ok( widget.hasClass( "ui-widget" ), "widget is .ui-widget" );
ok( widget.hasClass( "ui-widget-content" ), "widget is .ui-widget-content" );
ok( widget.hasClass( "ui-corner-all" ), "widget is .ui-corner-all" );
ok( widget.hasClass( "ui-dialog-buttons" ), "widget is .ui-dialog-buttons" );

ok( titlebar.hasClass( "ui-dialog-titlebar" ), "titlebar is .ui-dialog-titlebar" );
ok( titlebar.hasClass( "ui-corner-all" ), "titlebar is .ui-corner-all" );
ok( titlebar.hasClass( "ui-widget-header" ), "titlebar is .ui-widget-header" );
ok( titlebar.find( ".ui-dialog-title" ).length, "title is .ui-dialog-title" );

ok( close.hasClass( "ui-dialog-titlebar-close" ), "close button is .ui-dialog-titlebar-close" );

ok( element.hasClass( "ui-dialog-content" ), "element is .ui-dialog-content" );
ok( element.hasClass( "ui-widget-content" ), "element is .ui-widget-content" );

ok( buttonpane.hasClass( "ui-dialog-buttonpane" ), "buttonpane is .ui-dialog-buttonpane" );
ok( buttonpane.hasClass( "ui-widget-content" ), "buttonpane is .ui-widget-content" );
ok( buttonpane.find( ".ui-dialog-buttonset" ).length, "buttonset is .ui-dialog-buttonset" );

});

test("title id", function() {
expect(1);

Expand Down
68 changes: 68 additions & 0 deletions tests/unit/dialog/dialog_deprecated.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>jQuery UI Dialog Test Suite</title>

<script src="../../jquery.js"></script>
<script>
$.uiBackCompat = true;
</script>
<link rel="stylesheet" href="../../../external/qunit/qunit.css">
<script src="../../../external/qunit/qunit.js"></script>
<script src="../../../external/jquery-simulate/jquery.simulate.js"></script>
<script src="../testsuite.js"></script>
<script>
TestHelpers.loadResources({
css: [ "core", "dialog" ],
js: [
"ui/core.js",
"ui/widget.js",
"ui/position.js",
"ui/mouse.js",
"ui/draggable.js",
"ui/resizable.js",
"ui/button.js",
"ui/effect.js",
"ui/effect-blind.js",
"ui/effect-clip.js",
"ui/effect-explode.js",
"ui/dialog.js"
]
});
</script>

<script src="dialog_common_derecated.js"></script>
<script src="dialog_core.js"></script>
<script src="dialog_events.js"></script>
<script src="dialog_methods.js"></script>
<script src="dialog_options.js"></script>
<script src="dialog_deprecated.js"></script>
<script src="dialog_test_helpers.js"></script>

<script src="../swarminject.js"></script>
</head>
<body>

<div id="qunit"></div>
<div id="qunit-fixture">
<div id="dialog1"></div>
<div id="dialog2"></div>
<div id="form-dialog" title="Profile Information">
<!-- create a spacer to ensure there's enough space to scroll -->
<div style="height: 250px;">...</div>
<fieldset>
<legend>Please share some personal information</legend>
<label for="favorite-animal">Your favorite animal</label><input id="favorite-animal">
<label for="favorite-color">Your favorite color</label><input id="favorite-color">
</fieldset>
<div role="group" aria-describedby="section2">
<p id="section2">Some more (optional) information</p>
<label for="favorite-food">Favorite food</label><input id="favorite-food">
</div>
</div>
<div class="wrap" id="wrap1"></div>
<div class="wrap" id="wrap2"></div>
</div>
</body>
</html>
31 changes: 31 additions & 0 deletions tests/unit/dialog/dialog_deprecated.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
/*
* dialog_deprecated.js
*/
(function( $ ) {

module( "dialog (deprecated): options" );

test( "dialogClass", function() {
expect( 6 );

var element = $( "<div></div>" ).dialog(),
widget = element.dialog( "widget" );
equal( widget.is( ".foo" ), false, "dialogClass not specified. class not added" );
element.remove();

element = $( "<div></div>" ).dialog({ dialogClass: "foo" });
widget = element.dialog( "widget" );
equal( widget.is( ".foo" ), true, "dialogClass in init. foo class added");
element.dialog( "option", "dialogClass", "foobar" );
equal( widget.is( ".foo" ), false, "dialogClass changed, previous one was removed" );
equal( widget.is( ".foobar" ), true, "dialogClass changed, new one was added" );
element.remove();

element = $( "<div></div>" ).dialog({ dialogClass: "foo bar" });
widget = element.dialog( "widget" );
equal( widget.is( ".foo" ), true, "dialogClass in init, two classes. foo class added" );
equal( widget.is( ".bar" ), true, "dialogClass in init, two classes. bar class added" );
element.remove();
});

})( jQuery );
10 changes: 9 additions & 1 deletion tests/unit/dialog/dialog_methods.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ test("init", function() {
});

test("destroy", function() {
expect( 17 );
expect( 18 );

var element, element2;

Expand All @@ -49,6 +49,14 @@ test("destroy", function() {
equal( dialog.parent()[ 0 ], $( "#qunit-fixture" )[ 0 ] );
equal( dialog.index(), 2 );
});
domEqual( "#dialog2", function() {
$( "#dialog2" ).dialog({
buttons: [{
text: "Ok",
click: $.noop
}]
}).dialog( "destroy" );
}, "Buttons");

// Ensure dimensions are restored (#8119)
$( "#dialog1" ).show().css({
Expand Down
Loading