diff options
author | Scott González <scott.gonzalez@gmail.com> | 2011-01-24 13:33:24 -0500 |
---|---|---|
committer | Scott González <scott.gonzalez@gmail.com> | 2011-01-24 13:33:24 -0500 |
commit | cc90b440607a1af87c4abb8b2ee3325e96b0f5a1 (patch) | |
tree | 7152681fe4f4280f8ff6aa441163d7a7f1f29454 /tests/unit/widget | |
parent | bc71499a505d0932668b4ae75603cd9dbfd4a2ac (diff) | |
download | jquery-ui-cc90b440607a1af87c4abb8b2ee3325e96b0f5a1.tar.gz jquery-ui-cc90b440607a1af87c4abb8b2ee3325e96b0f5a1.zip |
Widget: Allow this.element to be the widget instance instead of a DOM element. Fixes #6895 - Widget: Allow non-DOM based widget.
Diffstat (limited to 'tests/unit/widget')
-rw-r--r-- | tests/unit/widget/widget_core.js | 32 |
1 files changed, 31 insertions, 1 deletions
diff --git a/tests/unit/widget/widget_core.js b/tests/unit/widget/widget_core.js index 189b75368..269b897c5 100644 --- a/tests/unit/widget/widget_core.js +++ b/tests/unit/widget/widget_core.js @@ -27,7 +27,7 @@ test( "widget creation", function() { }); test( "element normalization", function() { - expect( 10 ); + expect( 12 ); var elem; $.widget( "ui.testWidget", {} ); @@ -65,6 +65,14 @@ test( "element normalization", function() { same( elem.data( "testWidget" ), this, "instace stored in .data()" ); }; $.ui.testWidget( {}, "#element-normalization-selector" ); + + $.ui.testWidget.prototype.defaultElement = null; + $.ui.testWidget.prototype._create = function() { + // using strictEqual throws an error (Maximum call stack size exceeded) + ok( this.element[ 0 ] === this, "instance as element" ); + ok( this.element.data( "testWidget" ) === this, "instance stored in .data()" ); + }; + $.ui.testWidget(); }); test( "jQuery usage", function() { @@ -573,6 +581,28 @@ test( "._trigger() - provide event and ui", function() { .testWidget( "testEvent" ); }); +test( "._triger() - instance as element", function() { + expect( 4 ); + $.widget( "ui.testWidget", { + defaultElement: null, + testEvent: function() { + var ui = { foo: "bar" }; + this._trigger( "foo", null, ui ); + } + }); + var instance = $.ui.testWidget({ + foo: function( event, ui ) { + equal( event.type, "testwidgetfoo", "event object passed to callback" ); + same( ui, { foo: "bar" }, "ui object passed to callback" ); + } + }); + $( instance ).bind( "testwidgetfoo", function( event, ui ) { + equal( event.type, "testwidgetfoo", "event object passed to event handler" ); + same( ui, { foo: "bar" }, "ui object passed to event handler" ); + }); + instance.testEvent(); +}); + test( "auto-destroy - .remove()", function() { expect( 1 ); $.widget( "ui.testWidget", { |