aboutsummaryrefslogtreecommitdiffstats
path: root/tests/unit/tooltip/methods.js
diff options
context:
space:
mode:
Diffstat (limited to 'tests/unit/tooltip/methods.js')
-rw-r--r--tests/unit/tooltip/methods.js139
1 files changed, 139 insertions, 0 deletions
diff --git a/tests/unit/tooltip/methods.js b/tests/unit/tooltip/methods.js
new file mode 100644
index 000000000..3db7b8f7c
--- /dev/null
+++ b/tests/unit/tooltip/methods.js
@@ -0,0 +1,139 @@
+define( [
+ "jquery",
+ "ui/tooltip"
+], function( $ ) {
+
+module( "tooltip: methods" );
+
+test( "destroy", function( assert ) {
+ expect( 3 );
+ var element = $( "#tooltipped1" );
+
+ assert.domEqual( "#tooltipped1", function() {
+ element.tooltip().tooltip( "destroy" );
+ });
+
+ // make sure that open tooltips are removed on destroy
+ assert.domEqual( "#tooltipped1", function() {
+ element
+ .tooltip()
+ .tooltip( "open", $.Event( "mouseover", { target: element[0] }) )
+ .tooltip( "destroy" );
+ });
+ equal( $( ".ui-tooltip" ).length, 0 );
+});
+
+test( "open/close", function() {
+ expect( 3 );
+ $.fx.off = true;
+ var tooltip,
+ element = $( "#tooltipped1" ).tooltip();
+ equal( $( ".ui-tooltip" ).length, 0, "no tooltip on init" );
+
+ element.tooltip( "open" );
+ tooltip = $( "#" + element.data( "ui-tooltip-id" ) );
+ ok( tooltip.is( ":visible" ) );
+
+ element.tooltip( "close" );
+ ok( tooltip.is( ":hidden" ) );
+ $.fx.off = false;
+});
+
+// #8626 - Calling open() without an event
+test( "open/close with tracking", function() {
+ expect( 3 );
+ $.fx.off = true;
+ var tooltip,
+ element = $( "#tooltipped1" ).tooltip({ track: true });
+ equal( $( ".ui-tooltip" ).length, 0, "no tooltip on init" );
+
+ element.tooltip( "open" );
+ tooltip = $( "#" + element.data( "ui-tooltip-id" ) );
+ ok( tooltip.is( ":visible" ) );
+
+ element.tooltip( "close" );
+ ok( tooltip.is( ":hidden" ) );
+ $.fx.off = false;
+});
+
+test( "enable/disable", function( assert ) {
+ expect( 11 );
+ $.fx.off = true;
+ var tooltip,
+ element = $( "#tooltipped1" ).tooltip();
+ equal( $( ".ui-tooltip" ).length, 0, "no tooltip on init" );
+
+ element.tooltip( "open" );
+ tooltip = $( "#" + element.data( "ui-tooltip-id" ) );
+ ok( tooltip.is( ":visible" ) );
+
+ element.tooltip( "disable" );
+ equal( $( ".ui-tooltip" ).length, 0, "no tooltip when disabled" );
+
+ assert.lacksClasses( element.tooltip( "widget" ), "ui-state-disabled" );
+ ok( !element.tooltip( "widget" ).attr( "aria-disabled" ), "element doesn't get aria-disabled" );
+ assert.lacksClasses( element.tooltip( "widget" ), "ui-tooltip-disabled" );
+ equal( tooltip.attr( "title" ), null, "title removed on disable" );
+
+ element.tooltip( "open" );
+ equal( $( ".ui-tooltip" ).length, 0, "open does nothing when disabled" );
+
+ element.tooltip( "enable" );
+ equal( element.attr( "title" ), "anchortitle", "title restored on enable" );
+
+ // #9719 - Title should be preserved after disabling twice
+ element.tooltip( "disable" );
+ element.tooltip( "disable" );
+ element.tooltip( "enable" );
+ equal( element.attr( "title" ), "anchortitle", "title restored on enable after being disabled twice" );
+
+ element.tooltip( "open" );
+ tooltip = $( "#" + element.data( "ui-tooltip-id" ) );
+ ok( tooltip.is( ":visible" ) );
+ $.fx.off = false;
+});
+
+test( "widget", function() {
+ expect( 2 );
+ var element = $( "#tooltipped1" ).tooltip(),
+ widgetElement = element.tooltip( "widget" );
+ equal( widgetElement.length, 1, "one element" );
+ strictEqual( widgetElement[ 0 ], element[ 0 ], "same element" );
+});
+
+test( "preserve changes to title attributes on close and destroy", function() {
+ expect( 6 );
+ var element = $( "#tooltipped1" ),
+ changed = "changed title text",
+ original = "original title text",
+ tests = [];
+
+ // 1. Changes to title attribute are preserved on close()
+ tests[ 0 ] = { title: changed, expected: changed, method: "close" };
+ // 2. Changes to title attribute are preserved on destroy()
+ tests[ 1 ] = { title: changed, expected: changed , method: "destroy" };
+ // 3. Changes to title attribute are NOT preserved when set to empty string on close()
+ tests[ 2 ] = { title: "", expected: original, method: "close" };
+ // 4. Changes to title attribute are NOT preserved when set to empty string on destroy()
+ tests[ 3 ] = { title: "", expected: original, method: "destroy" };
+ // 5. Changes to title attribute NOT preserved when attribute has been removed on close()
+ tests[ 4 ] = { expected: original, method: "close" };
+ // 6. Changes to title attribute NOT preserved when attribute has been removed on destroy()
+ tests[ 5 ] = { expected: original, method: "destroy" };
+
+ $.each( tests, function( index, test ) {
+
+ element.attr( "title", original ).tooltip()
+ .tooltip( "open", $.Event( "mouseover", { target: element[ 0 ] } ) );
+ if ( test.title ) {
+ element.attr( "title", test.title );
+ } else {
+ element.removeAttr( "title" );
+ }
+ element.tooltip( test.method );
+ equal( $( "#tooltipped1" ).attr( "title" ), test.expected );
+
+ } );
+});
+
+} );