diff options
author | Richard Gibson <richard.gibson@gmail.com> | 2013-02-01 21:20:15 -0500 |
---|---|---|
committer | Dave Methvin <dave.methvin@gmail.com> | 2013-02-28 16:59:12 -0500 |
commit | 3f05afbd8d9bbc75d30b68e720324d1ed984a315 (patch) | |
tree | 0f08a3361dcbb0686a32e067ffa85049bc657eb7 /test | |
parent | 22a4e5bd0a7c0a92b54b9965984b582fd42099f2 (diff) | |
download | jquery-3f05afbd8d9bbc75d30b68e720324d1ed984a315.tar.gz jquery-3f05afbd8d9bbc75d30b68e720324d1ed984a315.zip |
Ref #13353, gh-1183: Capture onlyHandlers in jQuery.Event.isTrigger.
Diffstat (limited to 'test')
-rw-r--r-- | test/unit/event.js | 49 |
1 files changed, 35 insertions, 14 deletions
diff --git a/test/unit/event.js b/test/unit/event.js index 670fa9111..67d87ded0 100644 --- a/test/unit/event.js +++ b/test/unit/event.js @@ -1432,21 +1432,42 @@ test("jQuery.Event( type, props )", function() { }); -test("jQuery.Event.currentTarget", function(){ - expect(2); +test("jQuery.Event properties", function(){ + expect(12); - jQuery("<div><p><button>shiny</button></p></div>") - .on( "click", "p", function( e ){ - equal( e.currentTarget, this, "Check delegated currentTarget on event" ); - }) - .find( "button" ) - .on( "click", function( e ){ - equal( e.currentTarget, this, "Check currentTarget on event" ); - }) - .trigger("click") - .off( "click" ) - .end() - .off( "click" ); + var handler, + $structure = jQuery("<div id='ancestor'><p id='delegate'><span id='target'>shiny</span></p></div>"), + $target = $structure.find("#target"); + + handler = function( e ) { + strictEqual( e.currentTarget, this, "currentTarget at " + this.id ); + equal( e.isTrigger, 3, "trigger at " + this.id ); + }; + $structure.one( "click", handler ); + $structure.one( "click", "p", handler ); + $target.one( "click", handler ); + $target[0].onclick = function( e ) { + strictEqual( e.currentTarget, this, "currentTarget at target (native handler)" ); + equal( e.isTrigger, 3, "trigger at target (native handler)" ); + }; + $target.trigger("click"); + + $target.one( "click", function( e ) { + equal( e.isTrigger, 2, "triggerHandler at target" ); + }); + $target[0].onclick = function( e ) { + equal( e.isTrigger, 2, "triggerHandler at target (native handler)" ); + }; + $target.triggerHandler("click"); + + handler = function( e ) { + strictEqual( e.isTrigger, undefined, "native event at " + this.id ); + }; + $target.one( "click", handler ); + $target[0].onclick = function( e ) { + strictEqual( e.isTrigger, undefined, "native event at target (native handler)" ); + }; + fireNative( $target[0], "click" ); }); test(".delegate()/.undelegate()", function() { |